SSH框架總結(環境搭建+框架分析+實例源碼下載)


一、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>
pom.xml

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>
web.xml

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">
        &lt;!&ndash; 第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幫忙創建的實例  &ndash;&gt;
        <action name="login" class="com.zsm.ssh.action.UserAction">
            &lt;!&ndash; 跳轉是forward/WEB-INF/是防止jsp不經過action就可以訪問&ndash;&gt;
            &lt;!&ndash; result接收返回的字符串,然后做對應的事情 &ndash;&gt;
            &lt;!&ndash; 跳轉是forward/WEB-INF/是防止jsp不經過action就可以訪問&ndash;&gt;
            &lt;!&ndash; result接收返回的字符串,然后做對應的事情 &ndash;&gt;
         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>
struts.xml

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>
applicationContext.xml

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>
hibernate.cfg.xml

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>

        <!--&lt;!&ndash; 編號 &ndash;&gt;-->
        <!--<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>-->
        <!--&lt;!&ndash; 姓名 &ndash;&gt;-->
        <!--<property name="user_name" column="user_name" type="java.lang.String"></property>-->
        <!--&lt;!&ndash; 密碼 &ndash;&gt;-->
        <!--<property name="password" column="password" type="java.lang.String"></property>-->
        <!--&lt;!&ndash; 性別 &ndash;&gt;-->
        <!--<property name="user_sex" column="user_sex" type="java.lang.String"></property>-->
        <!--&lt;!&ndash; 生日 &ndash;&gt;-->
        <!--<property name="user_birthday" column="user_birthday" type="java.util.Date"></property>-->
        <!--&lt;!&ndash; 班級 &ndash;&gt;-->
        <!--<property name="user_class" column="user_class" type="java.lang.String"></property>-->
        <!--&lt;!&ndash; 創建時間 &ndash;&gt;-->
        <!--<property name="createtime" column="createtime" type="java.util.Date"></property>-->
        <!--&lt;!&ndash; 更新時間 &ndash;&gt;-->
        <!--<property name="updatetime" column="updatetime" type="java.util.Date"></property>-->
    </class>
</hibernate-mapping>
.hbm.xml

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
db-config.properties

三、框架分析

 

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/

本文是原創,歡迎大家轉載;但轉載時必須注明文章來源,且在文章開頭明顯處給明鏈接。
<歡迎有不同想法或見解的同學一起探討,共同進步>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM