spring4.1.2、hibernate4.3.7、struts2.3.16.3搭建学习例子

此种搭建框架的例子已有很多,本文只供参考。

环境

myeclipse5.5GA、mysql、tomcat6.0、jdk6.0

版本

spring4.1.2、hibernate4.3.7、struts2.3.16.3,可去官网下载。

jar包

application.properties

#mysql version database setting
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost/website?useUnicode=true&characterEncoding=utf-8
jdbc.username=root
jdbc.password=root
hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect

#hibernate settings
hibernate.show_sql=true
hibernate.format_sql=true

#dbcp settings
dbcp.initialSize=5
dbcp.maxActive=20
dbcp.maxIdle=10

applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://www.springframework.org/schema/beans" xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:cache="http://www.springframework.org/schema/cache" xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
       http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context-4.0.xsd
       http://www.springframework.org/schema/tx
       http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
       http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-4.0.xsd">

   <!-- 引入properties文件 -->
   <context:property-placeholder location="classpath*:/config/application.properties" />
   <!-- 定义数据库连接池数据源bean destroy-method="close"的作用是当数据库连接不使用的时候,就把该连接重新放到数据池中,方便下次使用调用 -->
   <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
       destroy-method="close">
       <!-- 设置JDBC驱动名称 -->
       <property name="driverClassName" value="${jdbc.driver}" />
       <!-- 设置JDBC连接URL -->
       <property name="url" value="${jdbc.url}" />
       <!-- 设置数据库用户名 -->
       <property name="username" value="${jdbc.username}" />
       <!-- 设置数据库密码 -->
       <property name="password" value="${jdbc.password}" />
		<!-- Connection Pooling Info -->
       <!-- 设置连接池初始值 -->
		<property name="initialSize" value="${dbcp.initialSize}" />
		<!-- 设置连接池最大连接数 -->
		<property name="maxActive" value="${dbcp.maxActive}" />
		<!-- 设置连接池最大空闲连接数 -->
		<property name="maxIdle" value="${dbcp.maxIdle}" />
		<property name="defaultAutoCommit" value="true" />
   </bean>
   
   <!-- 配置sessionFactory -->
   <bean id="sessionFactory"
       class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
       <!-- 数据源 -->
       <property name="dataSource" ref="dataSource" />
       <!-- hibernate的相关属性配置 -->
       <property name="hibernateProperties">
           <value>
               <!-- 设置数据库方言 -->
               hibernate.dialect=org.hibernate.dialect.MySQLDialect
               <!-- 设置自动创建|更新|验证数据库表结构 -->
               hibernate.hbm2ddl.auto=none
               <!-- 是否在控制台显示sql -->
               hibernate.show_sql=true
               <!-- 是否格式化sql,优化显示 -->
               hibernate.format_sql=true
               <!-- 是否开启二级缓存 -->
               hibernate.cache.use_second_level_cache=false
               <!-- 是否开启查询缓存 -->
               hibernate.cache.use_query_cache=false
               <!-- 数据库批量查询最大数 -->
               hibernate.jdbc.fetch_size=50
               <!-- 数据库批量更新、添加、删除操作最大数 -->
               hibernate.jdbc.batch_size=50
               <!-- 是否自动提交事务 -->
               hibernate.connection.autocommit=true
               <!-- 指定hibernate在何时释放JDBC连接 -->
               hibernate.connection.release_mode=auto
               <!-- 创建session方式 hibernate4.x 的方式 -->
               hibernate.current_session_context_class=org.springframework.orm.hibernate4.SpringSessionContext
               <!-- javax.persistence.validation.mode默认情况下是auto的,就是说如果不设置的话它是会自动去你的classpath下面找一个bean-validation**包 
                   所以把它设置为none即可 -->
               javax.persistence.validation.mode=none
               <!-- hibernate.enable_lazy_load_no_trans=true-->
           </value>
       </property>
       
       <!-- 自动扫描实体对象 tdxy.bean的包结构中存放实体类 -->
       <property name="packagesToScan" value="com.blz.*.bean" />
   </bean>
   <!-- 定义事务管理 -->
   <bean id="transactionManager"
       class="org.springframework.orm.hibernate4.HibernateTransactionManager">
       <property name="sessionFactory" ref="sessionFactory" />
   </bean>
   <!-- 定义 Autowired  自动注入 bean -->
   <bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/> 
   <!-- 扫描有注解的文件  base-package 包路径 -->
    <context:component-scan base-package="com.blz"/>
    <!-- 配置方法相对应的事务属性 -->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <!-- 事务执行方式 REQUIRED:指定当前方法必需在事务环境中运行,
                如果当前有事务环境就加入当前正在执行的事务环境,
                如果当前没有事务,就新建一个事务。这是默认值。 
             -->
            <tx:method name="create*" propagation="REQUIRED" />
            <tx:method name="save*" propagation="REQUIRED" />
            <tx:method name="add*" propagation="REQUIRED" />
            <tx:method name="update*" propagation="REQUIRED" />
            <tx:method name="remove*" propagation="REQUIRED" />
            <tx:method name="del*" propagation="REQUIRED" />
            <tx:method name="import*" propagation="REQUIRED" />
            <!-- 
                指定当前方法以非事务方式执行操作,如果当前存在事务,就把当前事务挂起,等我以非事务的状态运行完,再继续原来的事务。 
                查询定义即可 read-only="true"  表示只读
             -->
            <tx:method name="*" propagation="NOT_SUPPORTED" read-only="true" />
        </tx:attributes>
    </tx:advice>
    <!-- 定义切面,在 * com.blz.*.service.*ServiceImpl.*(..) 中执行有关的hibernate session的事务操作 -->
    <aop:config>
        <aop:pointcut id="serviceOperation" expression="execution(* com.blz.*.service.*Service.*(..))" />
        <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceOperation" />
    </aop:config>
</beans>

sturts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
        "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
	<constant name="struts.enable.DynamicMethodInvocation" value="true" />
	<constant name="struts.convention.default.parent.package" value="crud-default" />
	<constant name="struts.convention.package.locators" value="action,web" />
	<constant name="struts.convention.package.locators.basePackage" value="" />
	<!-- 用于CRUD Action的parent package -->
	<package name="crud-default" extends="convention-default">
		<!--
			基于paramsPrepareParamsStack, 增加store
			interceptor保证actionMessage在redirect后不会丢失
		-->
		<interceptors>
			<interceptor-stack name="crudStack">
				<interceptor-ref name="store">
					<param name="operationMode">AUTOMATIC</param>
				</interceptor-ref>
				<interceptor-ref name="paramsPrepareParamsStack" />
			</interceptor-stack>
		</interceptors>

		<default-interceptor-ref name="crudStack" />

	</package>

	<!--
		使用Convention插件,实现约定大于配置的零配置文件风格. 特殊的Result路径在Action类中使用@Result设定.
	-->
</struts>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	xmlns="http://java.sun.com/xml/ns/javaee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
	
	<!-- 加载spring配置文件 -->
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath*:/config/applicationContext.xml</param-value>
	</context-param>

	
	<!-- 启用spring监听 -->
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>

	
	<!-- 添加对struts2的支持 -->  
	<filter>  
		<filter-name>struts2</filter-name>  
		<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>  
		 <init-param>
            <param-name>config</param-name>
           <!-- 配置装载struts.xml路径,其中struts.xml放在/src/struts/下-->
            <param-value>struts-default.xml,struts-plugin.xml,config/struts.xml</param-value>
        </init-param>
	</filter> 
	
	<!-- Hibernate Open Session In View filter-->
	<filter>
		<filter-name>hibernateOpenSessionInViewFilter</filter-name>
		<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
	</filter>
	
	<filter-mapping>  
		<filter-name>struts2</filter-name>  
		<url-pattern>*.action</url-pattern>
		<dispatcher>REQUEST</dispatcher>
		<dispatcher>FORWARD</dispatcher> 
	</filter-mapping>
	
	<filter-mapping>
		<filter-name>hibernateOpenSessionInViewFilter</filter-name>
		<url-pattern>*.action</url-pattern>
		<dispatcher>REQUEST</dispatcher>
		<dispatcher>FORWARD</dispatcher>
	</filter-mapping>
	
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

下载地址

http://download.csdn.net/detail/djl100/8199617

几点说明

1、在dao包里实现方法的时候可以引用springside3-core-3.3.2.jar,继承HibernateDao类这样增、删、改、查的方法就不用自己写了。

2、使用load方法的时候,hibernate配置里要用hibernate.enable_lazy_load_no_trans=true,其它方法不需要。

3、添加事物的时候可以用注解,在application.xml里添加 <tx:annotation-driven transaction-manager="transactionManager"  proxy-target-class="true" />在方法或类上加

@Transactional。这样可以是配置更简洁。

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值