注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

星期五

明天不上班

 
 
 

日志

 
 
关于我

一个特立独行的Java程序员,比较宅,上上网,写博客,听音乐,看电影。

网易考拉推荐

2011年9月9日  

2011-07-16 10:34:51|  分类: Java |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

此例是用在WEB项目中,整合SSH(struts+spring+hibernate),用spring来管理事务和数据源,其中数据库连接文件通过属性文件来配置
一、spring的配置文件,配置数据源和事务
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<!--读取数据库连接配置文件-->
<bean
>
<property name="locations">
<!--数据库连接配置文件路径及文件名-->
<value>/WEB-INF/jdbc.properties</value>
<!--数据库连接配置文件如果放在SRC目录下则用以下配置-->
<!--
<value>classpath:jdbc.properties</value>
-->
</property>
</bean>

<bean id="dataSource"

destroy-method="close">
<property name="driverClassName"
value="${jesun.driverClassName}" />
<property name="url" value="${jesun.url}" />
<property name="username" value="${jesun.username}" />
<property name="password" value="${jesun.password}" />
</bean>

<bean id="sessionFactory" >
<!-- 配置数据源 -->
<property name="dataSource">
<ref local="dataSource"/>
</property>
<!-- 配置hibernate映射文件 -->
<property name="mappingLocations">
<list>
<value>classpath:/com/jesun/**/*.hbm.xml</value>
</list>
</property>
<!-- 以上配置映射文件还可以这样写(写具体的映射文件路径,但有点麻烦) -->
<!-->property name="mappingResources">
<list>
<value>com/jesun/test/test.hbm.xml</value>
</list>
</property-->
<property name="hibernateProperties">
<props>
<!--
<prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop> -->
<!--prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop -->
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.jdbc.batch_size">50</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
</bean>

<!-- 定义hibernate的sessionFactory
<bean id="sessionFactory"
>
<property name="configLocation"
value="classpath:hibernate.cfg.xml">
</property>
</bean> -->
<!-- 定义事务管理器 -->
<bean id="transactionManager"
>
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean>
<!-- 暂时不用
<bean id="baseTranProxy" abstract="true"
>
<property name="transactionManager" ref="transactionManager" />
<property name="transactionAttributes">
<props>

<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="delete*">PROPAGATION_REQUIRED</prop>
<prop key="find*">PROPAGATION_REQUIRED</prop>

<prop key="*">readOnly</prop>
</props>
</property>
</bean>
-->

<bean id="transactionInterceptor"
>
<property name="transactionManager">
<ref bean="transactionManager" />
</property>
<!-- 配置事务传播特性 -->
<property name="transactionAttributes">
<props>
<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="delete*">PROPAGATION_REQUIRED</prop>
<prop key="find*">PROPAGATION_REQUIRED</prop>
<prop key="*">readOnly</prop>
</props>
</property>
</bean>

<bean id="autoproxy"
>
<!-- 为所有以Svr结尾的Bean添加事务(业务层) -->
<property name="beanNames">
<list>
<value>*Svr</value>
</list>
</property>
<property name="interceptorNames">
<list>
<value>transactionInterceptor</value>
</list>
</property>
</bean>
</beans>
其中,jdbc.properties文件的内容如下:
#----------------------MySql-------------------------
jesun.driverClassName=com.mysql.jdbc.Driver
#jesun.url=jdbc:mysql://localhost:3306/websites
jesun.url=jdbc:mysql://localhost:3306/websites?useUnicode=true&characterEncoding=UTF-8
jesun.username=root
jesun.password=root
#---------------------MsSql--------------------------
#jesun.driverClassName=net.sourceforge.jtds.jdbc.Driver
#jesun.url=jdbc:jtds:sqlserver://127.0.0.1:1433/websites
#jesun.username=sa
#jesun.password=sa
#---------------------Oracle-------------------------
#jesun.driverClassName=oracle.jdbc.driver.OracleDriver
#jesun.url=jdbc:oracle:thin:@192.168.0.219:1521:orcl
#jesun.username=root
#jesun.password=root
二、项目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">
<filter>
<description>配置struts2过滤器</description>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<description>加载spring</description>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<context-param>
<description>加载所有spring配置文件</description>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/*-spring.xml</param-value>
</context-param>

<filter>
<description>使用openSessionInVew模式,保证事务一致性</description>
<filter-name>OpenSessionInViewFilter</filter-name>
<filter-class>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>OpenSessionInViewFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
这样,大功告成

  评论这张
 
阅读(161)| 评论(0)
推荐

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017