spring配置文件各个属性详解
分类: spring 2012-08-09 11:25 9316人阅读 评论(2) 收藏 举报
springaophibernateattributesxhtmlwebsphere
目录(?)[+]
1.
2. 第一种是DBCP数据源需要加入2个jar文件在spring中的lib下jakarta-commonscommons-dbcpjar和commons-poolsjar主要配置如下
3. 第二种是c3p0数据源跟第一种一个类型需加入c3p0jar包
4. 第三种是JNDI数据源配置在高性能的应用服务器如WebLogicWebSphere等
5. Spring JDBC 和 iBatis事务管理器的配置
6. Hibernate3以上事务管理器的配置先要集成hibernate再配置事务管理器
7.
8. 配置txaop声明式事务
一、引用外部属性文件
<bean id="propertyConfigurer" class="org.springframework.fig.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<property name="locations">
<list>
<value>classpath:mail.properties</value>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>
我们定义了一个PropertyPlaceholderConfigurer类的实例,并将其位置属性设置为我们的属性文件。该类被实现为Bean工厂的后处理器,并将使用定义在文件中的属性来代替所有的占位符(${...}value)。
注意:
而在spring2.5的版本中提供了一种更简便的方式,如:
1. <context:property-placeholder location="classpath:config/jdbc.properties"/>
这样以后要使用属性文件中的资源时,可以使用${属性名}来获得。
二、常用数据源的配置
第一种是:spring怎么读取配置DBCP数据源,(需要加入2个jar文件,在spring中的lib下jakarta-commons/commons-dbcp.jar和commons-pools.jar)主要配置如下:
<!-- Mysql版 -->
<bean id="dataSource"
class="org.apachemons.dbcp.BasicDataSource">
<property name="driverClassName"
value="sql.jdbc.Driver">
</property>
<property name="url"
value="${jdbc.url}">
<bean id="dataSource"
class="org.apachemons.dbcp.BasicDataSource">
<property name="driverClassName"
value="sql.jdbc.Driver">
</property>
<property name="url"
value="${jdbc.url}">
</property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
第二种是:c3p0数据源,跟第一种一个类型,需加入c3p0.jar包。
第三种是:JNDI数据源,配置在高性能的应用服务器(如WebLogic、WebSphere等)
1. <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
2. <property name="jndiName" value="java:comp/env/jdbc/bbt"/>
3. </bean>
从spring2.0开始提供jee命名空间,可以简化配置如下:
1. <jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/bbt"/>
三、配置事务管理器
1、Spring JDBC 和 iBatis事务管理器的配置
<!-- 配置事务管理器 -->
<bean id="TransactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
2、Hibernate3以上事务管理器的配置(先要集成hibernate,再配置事务管理器)
1. <!-- 集成hibernate -->
2. <bean id="sessionFactory" class="hibernate3.LocalSessionFactoryBean">
3. <property name="dataSource" ref="dataSource"/>
4. <property name="mappingResources">
5. <list>
6. <value>classpath:l</value>
7. </list>
8. </property>
9. <property name="hibernateProperties">
10. <props>
11. <prop key="hibernate.dialect">
12. </props>
13. </property>
14. </bean>
15.
16. <!-- 配置Hibernate事务策略 -->
17. <bean id="txManager" class="hibernate3.HibernateTransactionManager">
18. <property name="sessionFactory" ref="sessionFactory"></property>
19. </bean>
3、配置tx/aop声明式事务
<!-- 声明一个切面 -->
1. <tx:advice id="txAdvice" transaction-manager="txManager">
2. <tx:attributes>
3. <tx:method name="find*" propagation="REQUIRED" read-only="true"/>
4. <tx:method name="save*" propagation="REQUIRED"/>
5. <tx:method name="update*" propagation="REQUIRED"/>
6. <tx:method name="*" propagation="SUPPORTS" read-only="true" />
7. </tx:attributes>
8. </tx:advice>
别的例子,可以进行对比下:
<tx:advice id="userTxAdvice" transaction-manager="TransactionManager">
<tx:attributes>
<tx:method name="delete*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" no-rollback-for="java.lang.RuntimeException"/>
<tx:attributes>
<tx:method name="delete*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" no-rollback-for="java.lang.RuntimeException"/>
<tx:method name="insert*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.RuntimeException" />
<tx:method name="update*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" />
<tx:method name="find*" propagation="SUPPORTS"/>
<tx:method name="get*" propagation="SUPPORTS"/>
<tx:method name="select*" propagation="SUPPORTS"/>
</tx:attributes>
</tx:advice>
rollback-for="java.lang.Exception" />
<tx:method name="find*" propagation="SUPPORTS"/>
<tx:method name="get*" propagation="SUPPORTS"/>
<tx:method name="select*" propagation="SUPPORTS"/>
</tx:attributes>
</tx:advice>
<!-- 把切面注入到业务中 -->
1. <aop:config>
2. <aop:pointcut id="productServiceMethods" expression="execution(* com.wzc.student.business.*.*(..))" />
3. <aop:advisor advice-ref="txAdvice" pointcut-ref="productServiceMethods" />
4. </aop:config>
对比:
<aop:config>
<aop:pointcut id="pc" expression="execution(public * com.haso.bscsserver.service.*.*(..))" /> <!--把事务控制在Service层-->
<aop:advisor pointcut-ref="pc" advice-ref="userTxAdvice" />
</aop:config>
<aop:pointcut id="pc" expression="execution(public * com.haso.bscsserver.service.*.*(..))" /> <!--把事务控制在Service层-->
<aop:advisor pointcut-ref="pc" advice-ref="userTxAdvice" />
</aop:config>
四、context:component-scan
<!-- 对包中的所有类进行扫描,以完成Bean创建和自动依赖注入的功能 -->
<context:component-scan base-package="com.haso.bscsserver">
<!-- 允许定义过滤器将基包下的某些类纳入或排除
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> -->
</context:component-scan>
<context:component-scan base-package="com.haso.bscsserver">
<!-- 允许定义过滤器将基包下的某些类纳入或排除
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> -->
</context:component-scan>
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论