SSH框架版本:Struts-2.3.30  +  Spring-4.2.2  +  Hibernate5.2.2

下图是所需要的Jar包:

下面是项目的结构图:

1、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> <!-- 配置struts2核心的过滤器 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter> <filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <!-- Spring管理配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext-*.xml</param-value>
</context-param> <!-- Spring监听器 -->
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener> <!-- 配置请求过滤器,编码格式设为UTF-8,避免中文乱码-->
<filter>
<filter-name>springUtf8Encoding</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>springUtf8Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>

2、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">
<struts>
<!--开启开发模式-->
<constant name="struts.devMode" value="true"/>
<!--使用简单样式 -->
<constant name="struts.ui.theme" value="simple" />
<!-- 表示使用spring框架,本配置文件中所有action都要到spring配置文件中查找 -->
<constant name="struts.objectFactory" value="spring" /> <package name="default" extends="struts-default"> <!-- action实际配置在applicationContext.xml配置文件中 -->
<action name="grid" class="scoreAction" method="grid">
</action> </package>
</struts>

3、db.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false
jdbc.user=root
jdbc.password=root

4、applicationContext-common.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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation=" 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
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <!-- 加载外部properties文件 -->
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location" value="WEB-INF/db.properties"/>
</bean> <!-- 采用C3P0数据库连接池方式连接数据库 -->
<bean id= "candy" class ="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close" >
<property name="driverClass" value="${jdbc.driver}"> </property>
<property name="jdbcUrl" value="${jdbc.url}"> </property>
<property name="user" value="${jdbc.user}"> </property>
<property name="password" value="${jdbc.password}"> </property> <!-- 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 1 -->
<property name="acquireIncrement" value="1" ></property>
<!-- 初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
<property name="initialPoolSize" value="10" ></property>
<!-- 最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
<property name="maxIdleTime" value="60"></property>
<!-- 连接池中保留的最大连接数。Default: 15 -->
<property name="maxPoolSize" value="150"></property>
<!-- 连接池中保留的最小连接数。Default: 3 -->
<property name="minPoolSize" value="5"></property>
<!-- 两次连接中间隔时间,单位毫秒。Default: 1000 -->
<property name="acquireRetryDelay" value="1000"></property>
<!-- 定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
<property name="acquireRetryAttempts" value="60"></property>
<!-- 获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效-->
<!-- 保留,并在下次调用GETCONNECTION()的时候继续尝试获取连接。如果设为TRUE,那么在尝试-->
<!-- 获取连接失败后该数据源将申明已断开并永久关闭。DEFAULT: FALSE -->
<property name="breakAfterAcquireFailure" value="false" ></property>
</bean> <!-- 取代HiberbnateSessionFactory.java -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<!-- 设置注入 -->
<property name="dataSource">
<ref bean="candy" />
</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>
<!-- 是否允许Hibernate用JDBC的可滚动的结果集 -->
<prop key="hibernate.jdbc.use_scrollable_resultset">
false
</prop> </props>
</property>
<!-- 说明映射文件 -->
<property name="mappingResources">
<list>
<value>ssh/entity/Score.hbm.xml</value>
</list>
</property>
</bean> <!-- 事物管理 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean> <bean id="transactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">
<property name="transactionManager" ref="transactionManager"></property>
<property name="transactionAttributes">
<props>
<prop key="save*">PROPAGATION_REQUIRED, -Exception</prop>
<prop key="add*">PROPAGATION_REQUIRED, -Exception</prop>
<prop key="update*">PROPAGATION_REQUIRED, -Exception</prop>
<prop key="delete*">PROPAGATION_REQUIRED, -Exception</prop>
<prop key="find*">PROPAGATION_REQUIRED, readOnly</prop>
</props>
</property>
</bean> <!-- <bean id="userDao" parent="transactionProxy">
<property name="target">
用bean代替ref的方式
<bean class="com.dao.UserDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
</property>
</bean> --> </beans>

5、applicationContext-beans.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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation=" 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
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <!--配置bean -->
<!-- <bean id="baseDaoImpl" class="ssh.base.BaseDaoImpl" scope="prototype">
<property name="sessionFactory" >
<ref bean="sessionFactory"/>
</property>
</bean> <bean id="baseServiceImpl" class="ssh.service.impl.BaseServiceImpl" scope="prototype">
<property name="baseDao" >
<ref bean="baseDaoImpl"/>
</property>
</bean> --> <bean id="scoreDaoImpl" class="ssh.dao.impl.ScoreDaoImpl" scope="prototype">
<property name="sessionFactory" >
<ref bean="sessionFactory"/>
</property>
</bean> <bean id="scoreServiceImpl" class="ssh.service.impl.ScoreServiceImpl" scope="prototype">
<property name="scoreDao" >
<ref bean="scoreDaoImpl"/>
</property>
</bean> </beans>

6、applicationContext-actions.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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation=" 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
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <bean id="scoreAction" class="ssh.action.ScoreAction" scope="prototype">
<property name="scoreService">
<ref bean="scoreServiceImpl"/>
</property>
</bean> </beans>

7、log4j.properties

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS} %-5p [%F\:%L]%x %m%n log4j.appender.fileout=org.apache.log4j.RollingFileAppender
log4j.appender.fileout.File=D://application.log
log4j.appender.fileout.MaxFileSize=10000KB
log4j.appender.fileout.MaxBackupIndex=10
log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
log4j.appender.fileout.layout.ConversionPattern=%d{MM-dd HH:mm:ss.SSS}[%24F:%-3L:%-5p]%x %m%n log4j.rootCategory=INFO, stdout
log4j.logger.com.wolfsquare.log2=DEBUG,stdout

最新文章

  1. IP地址
  2. 转 夕甲甲:孔乙己之 C++ 版
  3. 3515 如何调试AT指令、查看拨号模块的打印
  4. 基于HT for Web的3D呈现A* Search Algorithm
  5. Android屏幕禁止休眠的方法
  6. golang channel 用法转的
  7. centos7 gitlab
  8. [转]Debug 和 Release 编译方式的区别
  9. MySQL数据库学习笔记(六)----MySQL多表查询之外键、表连接、子查询、索引
  10. jmeter断言
  11. hibernate简介(Session,几种状态,方法&#183;&#183;&#183;&#183;&#183;&#183;等)
  12. 使用Redis构建简单的ORM
  13. 手机字段存储报错 :Warning Code : 1264 Out of range value for column &#39;buyer_tpl&#39; at row 1
  14. lightswitch 添加 TreeView 控件
  15. 从TensorFlow到PyTorch:九大深度学习框架哪款最适合你?
  16. Expm 1_1 实现基于分治法的归并排序算法.
  17. jdk1.7环境配置
  18. SCSI共享磁盘
  19. Day 42 协程. IO 并发
  20. easyui input设置为disabled提交后获取不到属性值

热门文章

  1. Asp.Net Core 3.1学习-依赖注入、服务生命周期(6)
  2. js 函数的防抖(debounce)与节流(throttle) 带 插件完整解析版 [helpers.js]
  3. 【shell】Shell变量基础及深入
  4. 【Linux常见命令】route命令
  5. shell脚本(多线程批量创建用户)
  6. values/colors.xml
  7. vue-cli创建的webpack工程中引用ExtractTextPlugin导致css背景图设置无效的解决方法
  8. 前线观察 | AWS re:Invent 2018见闻实录
  9. webpack4.x下babel的安装、配置及使用
  10. Python爬虫(一)爬百度贴吧