一、SSH框架簡介
SSH是struts+spring+hibernate集成的web應用程序開源框架。
Struts:用來控制的,核心控制器是Controller。
Spring:對Struts和Hibernate進行管理,整合的。
Hiernate:操控數據庫
struts標簽庫:Struts2默認的表達式語言是OGNL(Object-Graph Navigation Language),通過它可以存取對象的任意屬性、調用對象的方法、遍歷整個對象的結構圖、實現字段類型轉換等功能。
JSP: HTML文件中插入Java程序段和JSP標記。
web.xml: Struts2核心過濾器和監聽器
struts.xml: 管理應用中的Action映射,及Action處理結果和物理資源之間的映射。
applicationContext.xml: 整合了struts和Hibernate。
*.hbm.xml:O/R Mapping(Object Relational Mapping)映射文件,實體和表的映射關系通過XML來描述的文件。在項目啟動的時候加載到內存中。
PO:Persistent Object,持久化對象
整體的調用關系:JSP–Action–Service–DAO–PO–數據庫
在表示層中,首先通過JSP頁面實現交互,負責接收請求(request)和傳送請求(response),Struts根據配置文件(struts.xml)將ActionServlet(Struts的內置核心控制器組件)接收到的Request請求委派給Action處理。
在業務層中,管理服務器組建的Spring IOC容器負責向Action提供業務模型(Model)組件和該組件的協作對象數據處理(DAO)組建完成業務邏輯,並提供事務處理、緩沖池等容器組件以提升和保持數據的完整性。
在持久層,依賴於Hibernate的對象化映射和數據庫交互,處理DAO組建請求的數據,並返回處理結果。
SSH框架優點:
1.spring管理對象的實例化,把對象的創建和獲取放到外部,更加的靈活方便。
2.Hibernate避免了JDBC連接數據庫的冗余繁雜。
3.各層分工明細,實現了各層之間的解耦,代碼更加靈活。
二、環境搭建
1.IDEA新建maven-webapp項目
2.Maven配置Struts,Spring,Hibernate依賴組件

<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <junit.version>4.12</junit.version> <!--JSONObject--> <json-lib.version>2.4</json-lib.version> <commons-lang.version>2.5</commons-lang.version> <commons-collections.version>3.2.1</commons-collections.version> <commons-beanutils.version>1.8.0</commons-beanutils.version> <commons-logging.version>1.2</commons-logging.version> <ezmorph.version>1.0.6</ezmorph.version> </properties> <dependencies> <!-- junit --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit.version}</version> <scope>test</scope> </dependency> <!--JSONObject--> <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</artifactId> <version>${json-lib.version}</version> <classifier>jdk15</classifier> </dependency> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId> <version>${commons-beanutils.version}</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>${commons-logging.version}</version> </dependency> <dependency> <groupId>net.sf.ezmorph</groupId> <artifactId>ezmorph</artifactId> <version>${ezmorph.version}</version> </dependency> <!--Struts 依賴組件--> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-core</artifactId> <version>2.5.14.1</version> </dependency> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-convention-plugin</artifactId> <version>2.5.14.1</version> </dependency> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-spring-plugin</artifactId> <version>2.5.14.1</version> </dependency> <dependency> <groupId>org.ow2.asm</groupId> <artifactId>asm</artifactId> <version>5.2</version> </dependency> <dependency> <groupId>org.ow2.asm</groupId> <artifactId>asm-commons</artifactId> <version>5.2</version> </dependency> <dependency> <groupId>cglib</groupId> <artifactId>cglib-nodep</artifactId> <version>2.1_3</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.3</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.5</version> </dependency> <dependency> <groupId>ognl</groupId> <artifactId>ognl</artifactId> <version>3.1.15</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.6</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.9.1</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.9.1</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts-annotations</artifactId> <version>1.0.6</version> </dependency> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.26-incubating</version> </dependency> <!--Spring dependencies--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-expression</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>4.1.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.1.9.RELEASE</version> <scope>test</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.4</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jsp-api</artifactId> <version>2.0</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.8.7</version> </dependency> <!--Hibernate Dependencies--> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>4.3.11.Final</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-ehcache</artifactId> <version>4.3.11.Final</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>4.3.11.Final</version> </dependency> <dependency> <groupId>net.sf.ehcache</groupId> <artifactId>ehcache</artifactId> <version>2.10.3</version> </dependency> <dependency> <groupId>antlr</groupId> <artifactId>antlr</artifactId> <version>2.7.7</version> </dependency> <dependency> <groupId>com.fasterxml</groupId> <artifactId>classmate</artifactId> <version>1.3.0</version> </dependency> <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId> <version>1.6.1</version> </dependency> <dependency> <groupId>org.hibernate.common</groupId> <artifactId>hibernate-commons-annotations</artifactId> <version>4.0.5.Final</version> </dependency> <dependency> <groupId>org.hibernate.javax.persistence</groupId> <artifactId>hibernate-jpa-2.1-api</artifactId> <version>1.0.0.Final</version> </dependency> <dependency> <groupId>org.javassist</groupId> <artifactId>javassist</artifactId> <version>3.18.1-GA</version> </dependency> <dependency> <groupId>org.jboss</groupId> <artifactId>jandex</artifactId> <version>1.1.0.Final</version> </dependency> <dependency> <groupId>org.apache.ant</groupId> <artifactId>ant</artifactId> <version>1.8.1</version> </dependency> <dependency> <groupId>org.jboss.logging</groupId> <artifactId>jboss-logging</artifactId> <version>3.1.3.GA</version> </dependency> <dependency> <groupId>org.jboss.logging</groupId> <artifactId>jboss-logging-annotations</artifactId> <version>1.2.0.Beta1</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.jboss.spec.javax.transaction</groupId> <artifactId>jboss-transaction-api_1.2_spec</artifactId> <version>1.0.0.Final</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.2</version> </dependency> <dependency> <groupId>org.jboss.spec.javax.transaction</groupId> <artifactId>jboss-transaction-api_1.2_spec</artifactId> <version>1.0.1.Final</version> </dependency> <dependency> <groupId>aopalliance</groupId> <artifactId>aopalliance</artifactId> <version>1.0</version> </dependency> <!--MySQL Driver--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.8-dmr</version> </dependency> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.5.2</version> </dependency> </dependencies>
3.配置web.xml

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>ssh</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <!-- spring --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:struts/applicationContext.xml</param-value> </context-param> <!-- spring監聽器 --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- struts攔截器 --> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 解決post亂碼 --> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--為解決lazy=true在jsp頁面上遍歷數據,此時相關類(one2many)再查找,沒有session的情況 --> <filter> <filter-name>hibernateFilter</filter-name> <filter-class> org.springframework.orm.hibernate4.support.OpenSessionInViewFilter </filter-class> <init-param> <param-name>singleSession</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>hibernateFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
4.配置struts.xml

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <!-- 上面的頭,注意版本,從樣例里復制過來 showcase.war\WEB-INF\src\java\struts.xml --> <struts> <!-- 告知Struts2運行時使用Spring來創建對象 --> <constant name="struts.objectFactory" value="spring"/> <!--<constant name="struts.convention.package.locators" value="controller"/>--> <!-- 自動掃描action包 --> <!-- 注解需要的jar包:struts2-convention-plugin --> <!--<constant name="struts.convention.default.parent.package" value="default"/>--> <!--<constant name="struts.convention.package.locators.basePackage" value="com.zsm.ssh.action" />--> <!--<constant name="struts.convention.package.locators" value="action"/>--> <!--<constant name="struts.conventresultJsonsult.path" value="/WEB-INF/jsp/"/>--> <!--<constant name="struts.convention.classes.reload" value="true"/>--> <constant name="struts.i18n.encoding" value="utf-8" /> <!--<constant name="struts.enable.DynamicMethodInvocation" value="true"/>--> <!-- 第1步:先定義一個包 namespace="/login"用於區別不同Action,需要添加到url中 采用注解不需配置--> <!--<package name="default" extends="struts-default"> <!– 第2步:定義一個action,配置跳轉信息 name 類似於Servlet @WebServlet("/IndexServlet") http://xxxx/xxx/Index.action http://xxxx/xxx/Index class 對應於自己寫的Action類 當不寫method屬性時,默認調用的是execute class="com.zsm.ssh.action.UserAction" ** new com.zsm.ssh.action.UserAction() 設計思想:關心了具體的實現類必須改為不要關注那個實現類 加入spring后,struts的action節點的class屬性意義發生變化, 直接引用spring幫忙創建的實例 –> <action name="login" class="com.zsm.ssh.action.UserAction"> <!– 跳轉是forward/WEB-INF/是防止jsp不經過action就可以訪問–> <!– result接收返回的字符串,然后做對應的事情 –> <!– 跳轉是forward/WEB-INF/是防止jsp不經過action就可以訪問–> <!– result接收返回的字符串,然后做對應的事情 –> resultJsonsult name="index" type="json">/index.jresultJsonsult> resultJsonsult name="success" type="json">/success.jresultJsonsult> resultJsonsult name="error">/error.jresultJsonsult> </action> </package>--> <!-- 所有匹配*.action的請求都由struts2處理 --> <constant name="struts.action.extension" value="action"/> <!-- 是否啟用開發模式 --> <constant name="struts.devMode" value="true"/> <!-- struts配置文件改動后,是否重新加載 --> <constant name="struts.configuration.xml.reload" value="true"/> <!-- 設置瀏覽器是否緩存靜態內容 --> <constant name="struts.serve.static.browserCache" value="false"/> <!-- 請求參數的編碼方式 --> <constant name="struts.i18n.encoding" value="utf-8"/> <!-- 每次HTTP請求系統都重新加載資源文件,有助於開發 --> <constant name="struts.i18n.reload" value="true"/> <!-- 文件上傳最大值 --> <constant name="struts.multipart.maxSize" value="104857600"/> <!-- 讓struts2支持動態方法調用 --> <constant name="struts.enable.DynamicMethodInvocation" value="true"/> <!-- Action名稱中是否還是用斜線 --> <constant name="struts.enable.SlashesInActionNames" value="false"/> <!-- 允許標簽中使用表達式語法 --> <constant name="struts.tag.altSyntax" value="true"/> <!-- 對於WebLogic,Orion,OC4J此屬性應該設置成true --> <constant name="struts.dispatcher.parametersWorkaround" value="false"/> <package name="basePackage" extends="struts-default"/> </struts>
5.配置applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsd" default-autowire="byName"> <!--default-lazy-init="true" 配置懶加載--> <!--自動掃描(實體類)注解包:實體類位置為:com.spring.mvc.entities.User,不能寫成:com.spring.mvc.entities,而要寫成:com.spring.mvc,packagesToScan要比實際上前一層--> <!--采用注解的方式注入action,service,dao --> <context:component-scan base-package="com.zsm.ssh.action"/> <context:component-scan base-package="com.zsm.ssh.service"/> <context:component-scan base-package="com.zsm.ssh.dao"/> <!-- 開啟SpringMVC注解模式 --> <!--<mvc:annotation-driven/>--> <!-- location值為參數配置文件的位置 --> <context:property-placeholder location="classpath:properties/db-config.properties"/> <!-- 屬性配置文件 --> <!--<bean id="propertyConfigeurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location"> <value>classpath:properties/db-config.properties</value> </property> </bean>--> <!-- 數據庫配置 --> <!-- 數據庫連接池 --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${jdbc.driver}"/> <property name="jdbcUrl" value="${jdbc.url}"/> <property name="user" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> <property name="maxPoolSize" value="${maxPoolSize}"/> <property name="minPoolSize" value="${minPoolSize}"/> <property name="autoCommitOnClose" value="${autoCommitOnClose}"/> <property name="checkoutTimeout" value="${checkoutTimeout}"/> <property name="acquireRetryAttempts" value="${acquireIncrement}"/> </bean> <!-- sessionFactory配置 --> <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"></property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> <property name="configLocation"> <!--mapper實例映射關系文件配置在cfg文件里--> <value>classpath:struts/hibernate.cfg.xml</value> </property> </bean> <!--spring對hibernate的事務管理 --> <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"></property> </bean> <tx:annotation-driven transaction-manager="transactionManager"/> <aop:config proxy-target-class="true"> <aop:pointcut expression="execution(* com.zsm.ssh.service..*(..))" id="serviceMethod"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceMethod"/> </aop:config> <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <!--默認: isolation:DEFAULT propagation:REQUIRED timeout:-1 事物超時時間由底層事物系統決定 read-only:false rollback-for:所有允許異常回滾 no-rollback-for:所有檢查異常不回滾 --> <tx:method name="get*" read-only="true"/> <tx:method name="do*"/> </tx:attributes> </tx:advice> </beans>
6.配置hibernate.cfg.xml

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- 數據庫連接配置 --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://localhost:3066/personal_test?characterEncoding=utf-8</property> <property name="connection.username">root</property> <property name="connection.password">123456</property> <!-- 每個數據庫都有1個,針對特定的關系型數據庫生成優化的SQL --> <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property> <!-- 設置默認的數據庫連接池 --> <property name="connection.pool_size">5</property> <!-- 顯示SQL --> <property name="show_sql">true</property> <!-- 格式化SQL --> <property name="format_sql">true</property> <!-- 根據schema更新數據表的工具 --> <property name="hbm2ddl.auto">update</property> <!-- 開啟二級緩存 --> <property name="cache.use_second_level_cache">true</property> <!-- 開啟查詢二級緩存 --> <property name="cache.use_query_cache">true</property> <!-- Hibernate4.0以上設置factory 緩存工具 --> <property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory </property> <!-- 二級緩存 ehcache的配置文件位置 --> <property name="hibernate.cache.provider_configuration_file_resource_path">struts/ehcache.xm</property> <!-- 數據表映射配置文件 --> <mapping resource="hibernate-mapper/User.hbm.xml"/> <!-- 需要緩存的類 read-only 無需修改,那么就可以對其進行只讀 緩存;read-write需要更新數據,那么使用讀/寫緩存 比較合適, 前提:數據庫不可以為serializable transaction isolation level(序列化事務隔離級別);nonstrice-read-write 只偶爾需要更新數據--> <!-- 需要緩存的類 --> <class-cache usage="read-only" class="com.zsm.ssh.model.User"/> </session-factory> </hibernate-configuration>
7.配置 .hbm.xml

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.zsm.ssh.model"> <class name="com.zsm.ssh.model.User" table="student"> <id name="id" type="java.lang.Integer"> <column name="id"/> <generator class="native"/> </id> <property name="user_no" type="java.lang.String"> <column name="user_no"> <comment>學號</comment> </column> </property> <property name="user_name" type="java.lang.String"> <column name="user_name"> <comment>名字</comment> </column> </property> <property name="password" type="java.lang.String"> <column name="password"> <comment>密碼</comment> </column> </property> <property name="user_sex" type="java.lang.String"> <column name="user_sex"> <comment>性別</comment> </column> </property> <property name="user_birthday" type="java.util.Date"> <column name="user_birthday"> <comment>生日</comment> </column> </property> <property name="user_class" type="java.lang.String"> <column name="user_class"> <comment>班級</comment> </column> </property> <property name="createtime" type="java.util.Date"> <column name="createtime"> <comment>創建時間</comment> </column> </property> <property name="updatetime" type="java.util.Date"> <column name="updatetime"> <comment>更新時間</comment> </column> </property> <!--<!– 編號 –>--> <!--<id name="id" column="id" type="int">--> <!--<generator class="native"></generator>--> <!--</id>--> <!--<property name="user_no" column="user_no" type="java.lang.String" not-null="true"></property>--> <!--<!– 姓名 –>--> <!--<property name="user_name" column="user_name" type="java.lang.String"></property>--> <!--<!– 密碼 –>--> <!--<property name="password" column="password" type="java.lang.String"></property>--> <!--<!– 性別 –>--> <!--<property name="user_sex" column="user_sex" type="java.lang.String"></property>--> <!--<!– 生日 –>--> <!--<property name="user_birthday" column="user_birthday" type="java.util.Date"></property>--> <!--<!– 班級 –>--> <!--<property name="user_class" column="user_class" type="java.lang.String"></property>--> <!--<!– 創建時間 –>--> <!--<property name="createtime" column="createtime" type="java.util.Date"></property>--> <!--<!– 更新時間 –>--> <!--<property name="updatetime" column="updatetime" type="java.util.Date"></property>--> </class> </hibernate-mapping>
8.數據庫連接

1 jdbc.driver=com.mysql.jdbc.Driver 2 jdbc.url=jdbc:mysql://localhost:3306/webapp?characterEncoding=utf-8&serverTimezone=GMT%2B8&useUnicode=true&useSSL=false 3 jdbc.username=root 4 jdbc.password=123456 5 #最大連接數 6 maxPoolSize=30 7 #最小連接數 8 minPoolSize=10 9 #關閉連接后不自動commit 10 autoCommitOnClose=false 11 #獲取連接超時時間 12 checkoutTimeout=10000 13 #當獲取連接失敗重試次數 14 acquireIncrement=2
三、框架分析
1.建立Action
1 package com.zsm.ssh.action; 2 3 import com.opensymphony.xwork2.ActionSupport; 4 import com.zsm.ssh.model.User; 5 import com.zsm.ssh.service.UserService; 6 import net.sf.json.JSONObject; 7 import org.apache.struts2.ServletActionContext; 8 import org.apache.struts2.convention.annotation.Action; 9 import org.apache.struts2.convention.annotation.Namespace; 10 import org.apache.struts2.convention.annotation.ParentPackage; 11 import org.apache.struts2.convention.annotation.Result; 12 import org.springframework.beans.factory.annotation.Autowired; 13 14 import javax.servlet.http.HttpServletRequest; 15 import javax.servlet.http.HttpServletResponse; 16 import java.io.PrintWriter; 17 18 19 /** 20 * @Author: zengsm. 21 * @Description: 22 * @Date:Created in 2017/12/6 15:45. 23 * @Modified By: 24 */ 25 //默認可以不寫 26 @ParentPackage("struts-default") 27 //根命名空間,可以不寫 28 @Namespace("/") 29 //全局配置,如果方法上不指定result,則使用該Result 30 //@Results({@Result(name="success",location="/success.jsp"), 31 // @Result(name="error",location="/error.jsp")}) 32 public class UserAction extends ActionSupport 33 { 34 //前台傳到后台需要set,后台傳到前台需要get 35 // 用戶名-必須與頁面請求的對應表單username值相同 36 private String username; 37 38 // 密碼必須與頁面請求的對應表單password值相同 39 private String password; 40 41 private String resultJson; 42 43 /* 44 * struts 接收參數三種方式:屬性方式接收,JavaBean方式接收,ModelDriven方式接收參數,前兩種都必須設置get和set方法 45 * */ 46 //Spring 注入方式 47 @Autowired 48 private UserService userService; 49 50 //@Action(value="login") 51 @Action(value = "login", results = { 52 @Result(name = "success", location = "/success.jsp", params = {"resultJson", "resultJson"}), 53 @Result(name = "error", location = "/error.jsp")}) 54 public String execute() throws Exception 55 { 56 HttpServletResponse response = ServletActionContext.getResponse(); 57 HttpServletRequest request = ServletActionContext.getRequest(); 58 59 JSONObject result = new JSONObject(); 60 User user = userService.getByName(username); 61 result.put("user", user); 62 63 if (user != null && user.getUser_name().equals(username) && user.getPassword().equals(password)) 64 { 65 result.put("message", "登錄成功"); 66 result.put("status", "true"); 67 resultJson = result.toString(); 68 request.setAttribute("resultJson", resultJson); 69 writeResponseData(request, response, result); 70 return "success"; 71 } 72 result.put("message", "登錄失敗"); 73 result.put("status", "false"); 74 resultJson = result.toString(); 75 writeResponseData(request, response, result); 76 return "error"; 77 } 78 79 private void writeResponseData(HttpServletRequest request, HttpServletResponse response, Object data) 80 { 81 response.setContentType("text/html;charset=utf-8"); 82 try 83 { 84 PrintWriter out = response.getWriter(); 85 out.println(data.toString()); 86 } 87 catch (Exception e) 88 { 89 e.printStackTrace(); 90 } 91 } 92 93 public String getUsername() 94 { 95 return username; 96 } 97 98 public void setUsername(String username) 99 { 100 this.username = username; 101 } 102 103 public void setPassword(String password) 104 { 105 this.password = password; 106 } 107 108 public String getResultJson() 109 { 110 return resultJson; 111 } 112 113 public void setResultJson(String resultJson) 114 { 115 this.resultJson = resultJson; 116 } 117 }
2.建立Service接口和實現類
1 package com.zsm.ssh.service; 2 3 import com.zsm.ssh.model.User; 4 5 import java.util.List; 6 7 8 /** 9 * @Author: zengsm. 10 * @Description: 11 * @Date:Created in 2017/12/6 15:30. 12 * @Modified By: 13 */ 14 public interface UserService 15 { 16 List<User> findAllUser(); 17 18 int saveEntity(User user); 19 20 boolean saveOrUpdateEntity(User user); 21 22 boolean updateEntity(User user); 23 24 User getByName(String name); 25 26 User getByNo(String no); 27 28 boolean deleteUserById(Integer id); 29 30 boolean deleteUserByNo(String no); 31 32 boolean deleteUserByEntity(User user); 33 }
1 package com.zsm.ssh.service.impl; 2 3 import com.zsm.ssh.dao.UserDao; 4 import com.zsm.ssh.model.User; 5 import com.zsm.ssh.service.UserService; 6 import org.springframework.beans.factory.annotation.Autowired; 7 import org.springframework.stereotype.Service; 8 import org.springframework.transaction.annotation.Transactional; 9 10 import java.util.List; 11 12 13 /** 14 * @Author: zengsm. 15 * @Description: 16 * @Date:Created in 2017/12/6 15:31. 17 * @Modified By: 18 */ 19 @Service("userService") 20 @Transactional 21 public class UserServiceImpl implements UserService 22 { 23 @Autowired 24 private UserDao userDao; 25 26 @Override 27 public List<User> findAllUser() 28 { 29 List<User> allUser = userDao.findAllUser(); 30 return allUser; 31 } 32 33 @Override 34 public int saveEntity(User user) 35 { 36 int id = userDao.saveEntity(user); 37 return id; 38 } 39 40 @Override 41 public boolean saveOrUpdateEntity(User user) 42 { 43 try 44 { 45 userDao.saveOrUpdateEntity(user); 46 return true; 47 } 48 catch (Exception e) 49 { 50 e.printStackTrace(); 51 return false; 52 } 53 } 54 55 @Override 56 public boolean updateEntity(User user) 57 { 58 try 59 { 60 userDao.updateEntity(user); 61 return true; 62 } 63 catch (Exception e) 64 { 65 e.printStackTrace(); 66 return false; 67 } 68 } 69 70 @Override 71 public User getByName(String name) 72 { 73 try 74 { 75 User user = userDao.getByName(name); 76 return user; 77 } 78 catch (Exception e) 79 { 80 e.printStackTrace(); 81 return null; 82 } 83 } 84 85 @Override 86 public User getByNo(String no) 87 { 88 try 89 { 90 User user = userDao.getByNo(no); 91 return user; 92 } 93 catch (Exception e) 94 { 95 e.printStackTrace(); 96 return null; 97 } 98 } 99 100 @Override 101 public boolean deleteUserById(Integer id) 102 { 103 try 104 { 105 userDao.deleteUserById(id); 106 return true; 107 } 108 catch (Exception e) 109 { 110 e.printStackTrace(); 111 return false; 112 } 113 } 114 115 @Override 116 public boolean deleteUserByNo(String no) 117 { 118 try 119 { 120 userDao.deleteUserByNo(no); 121 return true; 122 } 123 catch (Exception e) 124 { 125 e.printStackTrace(); 126 return false; 127 } 128 } 129 130 @Override 131 public boolean deleteUserByEntity(User user) 132 { 133 try 134 { 135 userDao.deleteUserByEntity(user); 136 return true; 137 } 138 catch (Exception e) 139 { 140 e.printStackTrace(); 141 return false; 142 } 143 } 144 }
3.建立Dao接口和實現類
1 package com.zsm.ssh.dao; 2 3 import com.zsm.ssh.model.User; 4 5 import java.util.List; 6 7 8 /** 9 * @Author: zengsm. 10 * @Description: 11 * @Date:Created in 2017/12/6 15:32. 12 * @Modified By: 13 */ 14 public interface UserDao 15 { 16 List<User> findAllUser(); 17 18 int saveEntity(User user); 19 20 void saveOrUpdateEntity(User user); 21 22 void updateEntity(User user); 23 24 User getByName(String name); 25 26 User getByNo(String no); 27 28 void deleteUserById(Integer id); 29 30 void deleteUserByNo(String no); 31 32 void deleteUserByEntity(User user); 33 }
1 package com.zsm.ssh.dao.impl; 2 3 import com.zsm.ssh.dao.UserDao; 4 import com.zsm.ssh.model.User; 5 import org.hibernate.Query; 6 import org.hibernate.Session; 7 import org.hibernate.SessionFactory; 8 import org.springframework.beans.factory.annotation.Autowired; 9 import org.springframework.orm.hibernate4.support.HibernateDaoSupport; 10 import org.springframework.stereotype.Repository; 11 import org.springframework.transaction.annotation.Propagation; 12 import org.springframework.transaction.annotation.Transactional; 13 14 import java.util.List; 15 16 17 /** 18 * @Author: zengsm. 19 * @Description: 20 * @Date:Created in 2017/12/6 15:36. 21 * @Modified By: 22 */ 23 @Repository("userDao") 24 public class UserDaoImpl extends HibernateDaoSupport implements UserDao 25 { 26 //這里的屬性名一定要和配置中的屬性名一致 27 @Autowired 28 private SessionFactory sessionFactory; 29 30 @Override 31 @Transactional(propagation = Propagation.REQUIRED) 32 public List<User> findAllUser() 33 { 34 Session session = sessionFactory.openSession(); 35 //將所有的數據查詢出來並放到List集合里 User是表對應的實例名稱 36 List<User> list = session.createQuery("from User").list(); 37 session.close(); 38 return list; 39 } 40 41 @Override 42 @Transactional(propagation = Propagation.REQUIRED) 43 public int saveEntity(User user) 44 { 45 Session session = sessionFactory.getCurrentSession(); 46 //返回插入數據id 47 Object id = session.save(user); 48 return Integer.valueOf(id.toString()); 49 } 50 51 @Override 52 @Transactional(propagation = Propagation.REQUIRED) 53 public void saveOrUpdateEntity(User user) 54 { 55 Session session = sessionFactory.getCurrentSession(); 56 session.saveOrUpdate(user); 57 } 58 59 @Override 60 @Transactional(propagation = Propagation.REQUIRED) 61 public void updateEntity(User user) 62 { 63 Session session = sessionFactory.getCurrentSession(); 64 session.update(user); 65 } 66 67 @Override 68 @Transactional(propagation = Propagation.REQUIRED) 69 public User getByName(String name) 70 { 71 Session session = sessionFactory.getCurrentSession(); 72 //根據id查詢,結果返回 User.class 73 User user = (User)session.get(User.class, 2); 74 //將所有的數據查詢出來並放到List集合里 User是表對應的實例名稱 75 List users = session.createQuery("from User where user_name='" + name + "'").list(); 76 return (User)users.get(0); 77 } 78 79 @Override 80 @Transactional(propagation = Propagation.REQUIRED) 81 public User getByNo(String no) 82 { 83 Session session = sessionFactory.getCurrentSession(); 84 List users = session.createQuery("from User where user_no='" + no + "'").list(); 85 return (User)users.get(0); 86 } 87 88 @Override 89 @Transactional(propagation = Propagation.REQUIRED) 90 public void deleteUserById(Integer id) 91 { 92 Session session = sessionFactory.getCurrentSession(); 93 String sql = "delete from User where id=:id"; 94 Query query = session.createQuery(sql); 95 query.setParameter("id", id); 96 query.executeUpdate(); 97 } 98 99 @Override 100 @Transactional(propagation = Propagation.REQUIRED) 101 public void deleteUserByNo(String no) 102 { 103 Session session = sessionFactory.getCurrentSession(); 104 String sql = "delete from User where user_no=:no"; 105 Query query = session.createQuery(sql); 106 query.setParameter("no", no); 107 query.executeUpdate(); 108 } 109 110 @Override 111 @Transactional(propagation = Propagation.REQUIRED) 112 public void deleteUserByEntity(User user) 113 { 114 Session session = sessionFactory.getCurrentSession(); 115 //傳入實例對象,比較id刪除對應行,,沒有id匹配就不刪除 116 session.delete(User.class.getName(), user); 117 } 118 }
四、源碼分享
歡迎Star個人GitHub:https://github.com/lovelifeming/Resource/tree/master/SSH
備注:
作者:Shengming Zeng
博客:http://www.cnblogs.com/zengming/
本文是原創,歡迎大家轉載;但轉載時必須注明文章來源,且在文章開頭明顯處給明鏈接。
<歡迎有不同想法或見解的同學一起探討,共同進步>