一、启动Spring2.5监听,让web项目整合spring
在web.xml中配置,代码如下:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:beans.xml</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
注:如果在支持低版本的Servlet的web容器中,可以采用Servlet形式,把上面的<listener>换成下面的<servlet>,优点是可以设置自启动顺序,代码如下:
<!-- 使用自动启动的Servlet进行初始化 -->
<servlet>
<servlet-name>contextLoaderServlet</servlet-name>
<servlet-class>
org.springframework.web.context.ContextLoaderServlet
</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
二、关于配置日志文件Log4J
由于WebApplicationContext需要使用日志功能,用户可以将Log4J的配置文件放到类路径WEB-INF/classes下,这Log4J引擎可以顺利启动。如果将Log4J配置文件放在其他位置,用户还需要在web.xml中指定Log4J的位置,spring也Log4J提供了两种方式,跟上面类似,有监听模式和自启动模式(Servlet模式)
监听模式:
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>
/WEB-INF/log4j.properties
</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.util.Log4jConfigListener
</listener-class>
</listener>
而自启动模式跟上面一样把listen换成servlet,如:
<servlet>
<servlet-name>log4jConfigServlet</servlet-name>
<servlet-class>
org.springframework.web.util.Log4jConfigServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
下面是一个简单的log4j.properties文件:
log4j.rootLogger=INFO,A1 log4j.appender.A1=org.apache.log4j.ConsoleAppender log4j.appender.A1.layout=org.apache.log4j.PatternLayout log4j.appender.A1.layout.ConversionPattern=%d %5p [%t] (%F:%L) - %m%n 注意:如果手动配置Log4J,则先要让日志文件Log4J先启动,再spring的监听或启动。
三、使用外部属性文件和配置数据源
a、使用外部属性文件
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list> <value>classpath:com/baobaotao/place/jdbc.properties</value> </list>
</property>
<property name="fileEncoding" value="utf-8" />
</bean>
而在spring2.5的版本中提供了一种更简便的方式,如:
<context:property-placeholder location="classpath:config/jdbc.properties"/>
这样以后要使用属性文件中的资源时,可以使用${属性名}来获得。
b、常用数据源的配置
第一种是:DBCP数据源,(需要加入2个jar文件,在spring中的lib下jakarta-commons/commons-dbcp.jar和commons-pools.jar)主要配置如下:
<!-- 配置数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3309/sampledb" />
<property name="username" value="root" />
<property name="password" value="1234" />
</bean>
第二种是:c3p0数据源,跟第一种一个类型,需加入c3p0.jar包。
第三种是:JNDI数据源,配置在高性能的应用服务器(如WebLogic、WebSphere等)
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/jdbc/bbt"/>
</bean>
从spring2.0开始提供jee命名空间,可以简化配置如下:
<jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/bbt"/> 四、事务管理配置
a、Spring JDBC 和 iBatis事务管理器的配置
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
b、Hibernate3以上事务管理器的配置(先要集成hibernate,再配置事务管理器)
<!-- 集成hibernate -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"/>
<property name="mappingResources">
<list>
<value>classpath:product.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
</props>
</property>
</bean>
<!-- 配置Hibernate事务策略 -->
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property> </bean>
五、配置tx/aop声明式事务
<!-- 配置tx/aop声明式事务 -->
<!-- 声明一个切面 -->
<tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes>
<tx:method name="find*" propagation="REQUIRED" read-only="true"/> <tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
<tx:method name="*" propagation="SUPPORTS" read-only="true" /> </tx:attributes>
</tx:advice>
<!-- 把切面注入到业务中 -->
<aop:config>
<aop:pointcut id="productServiceMethods" expression="execution(* com.wzc.student.business.*.*(..))" />
<aop:advisor advice-ref="txAdvice"
pointcut-ref="productServiceMethods" />
</aop:config>
六、使用基于@Transactional注解形式声明事务
在bean.xml通过一 行xml配置就可以,如
<tx:annotation-driven transaction-manager="txManager"/>
提示:如果你用 'transactionManager' 来定义 PlatformTransactionManager bean的名字的话,你就可以忽略
<tx:annotation-driven/> 标签里的 'transaction-manager' 属性。
这样在需要业务的接口或实现类中加上@Transactional就可以了,详细见文档。
七、spring的字符过滤器的配置
在web.xml中增加如下过滤器
<filter>
<filter-name>characterEncodingFilter</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>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
在web.xml中配置,代码如下:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:beans.xml</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
注:如果在支持低版本的Servlet的web容器中,可以采用Servlet形式,把上面的<listener>换成下面的<servlet>,优点是可以设置自启动顺序,代码如下:
<!-- 使用自动启动的Servlet进行初始化 -->
<servlet>
<servlet-name>contextLoaderServlet</servlet-name>
<servlet-class>
org.springframework.web.context.ContextLoaderServlet
</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
二、关于配置日志文件Log4J
由于WebApplicationContext需要使用日志功能,用户可以将Log4J的配置文件放到类路径WEB-INF/classes下,这Log4J引擎可以顺利启动。如果将Log4J配置文件放在其他位置,用户还需要在web.xml中指定Log4J的位置,spring也Log4J提供了两种方式,跟上面类似,有监听模式和自启动模式(Servlet模式)
监听模式:
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>
/WEB-INF/log4j.properties
</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.util.Log4jConfigListener
</listener-class>
</listener>
而自启动模式跟上面一样把listen换成servlet,如:
<servlet>
<servlet-name>log4jConfigServlet</servlet-name>
<servlet-class>
org.springframework.web.util.Log4jConfigServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
下面是一个简单的log4j.properties文件:
log4j.rootLogger=INFO,A1 log4j.appender.A1=org.apache.log4j.ConsoleAppender log4j.appender.A1.layout=org.apache.log4j.PatternLayout log4j.appender.A1.layout.ConversionPattern=%d %5p [%t] (%F:%L) - %m%n 注意:如果手动配置Log4J,则先要让日志文件Log4J先启动,再spring的监听或启动。
三、使用外部属性文件和配置数据源
a、使用外部属性文件
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list> <value>classpath:com/baobaotao/place/jdbc.properties</value> </list>
</property>
<property name="fileEncoding" value="utf-8" />
</bean>
而在spring2.5的版本中提供了一种更简便的方式,如:
<context:property-placeholder location="classpath:config/jdbc.properties"/>
这样以后要使用属性文件中的资源时,可以使用${属性名}来获得。
b、常用数据源的配置
第一种是:DBCP数据源,(需要加入2个jar文件,在spring中的lib下jakarta-commons/commons-dbcp.jar和commons-pools.jar)主要配置如下:
<!-- 配置数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3309/sampledb" />
<property name="username" value="root" />
<property name="password" value="1234" />
</bean>
第二种是:c3p0数据源,跟第一种一个类型,需加入c3p0.jar包。
第三种是:JNDI数据源,配置在高性能的应用服务器(如WebLogic、WebSphere等)
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/jdbc/bbt"/>
</bean>
从spring2.0开始提供jee命名空间,可以简化配置如下:
<jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/bbt"/> 四、事务管理配置
a、Spring JDBC 和 iBatis事务管理器的配置
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
b、Hibernate3以上事务管理器的配置(先要集成hibernate,再配置事务管理器)
<!-- 集成hibernate -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"/>
<property name="mappingResources">
<list>
<value>classpath:product.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
</props>
</property>
</bean>
<!-- 配置Hibernate事务策略 -->
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property> </bean>
五、配置tx/aop声明式事务
<!-- 配置tx/aop声明式事务 -->
<!-- 声明一个切面 -->
<tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes>
<tx:method name="find*" propagation="REQUIRED" read-only="true"/> <tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
<tx:method name="*" propagation="SUPPORTS" read-only="true" /> </tx:attributes>
</tx:advice>
<!-- 把切面注入到业务中 -->
<aop:config>
<aop:pointcut id="productServiceMethods" expression="execution(* com.wzc.student.business.*.*(..))" />
<aop:advisor advice-ref="txAdvice"
pointcut-ref="productServiceMethods" />
</aop:config>
六、使用基于@Transactional注解形式声明事务
在bean.xml通过一 行xml配置就可以,如
<tx:annotation-driven transaction-manager="txManager"/>
提示:如果你用 'transactionManager' 来定义 PlatformTransactionManager bean的名字的话,你就可以忽略
<tx:annotation-driven/> 标签里的 'transaction-manager' 属性。
这样在需要业务的接口或实现类中加上@Transactional就可以了,详细见文档。
七、spring的字符过滤器的配置
在web.xml中增加如下过滤器
<filter>
<filter-name>characterEncodingFilter</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>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>