Spring的配置文件

Spring的配置文件:applicationContext.xml

       1、代码: 

<?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:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd  
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd  
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">

       这一块我就不多说了 ,和以前一样啊!大家也无需修改滴。

       2、代码:              

<!-- 开启注解方式,用注解方式进行对bean的管理和依赖注入 -->
    <context:annotation-config />

       大家在Action和Service层的时候可能会遇到 @Resource、@Repository、 @Service、@Controller等等注解,只有加上上述代码,这些注解才会起作用的。  

       3、代码:              

<!-- 对指定的包进行组件扫描 -->
    <context:component-scan base-package="com.donglusoft" />

       是规定上述注解的扫描范围。  

       4、代码:              

<!-- 读取配置文件 -->
    <bean id="propertyConfigurer"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <list>
                <value>classpath*:conf/properties/jdbc.properties</value>
                <value>classpath*:conf/properties/c3p0.properties</value>
                <value>classpath*:conf/properties/hibernate.properties</value>
            </list>
        </property>
    </bean>

       作用:根据路径读取配置文件,比如:常用的数据库配置文件等等。

       5、代码:              

<!-- 配置c3p0数据源,导入c3p0-0.9.1.2.jar -->
    <bean id="c3p0DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driverClassName}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <property name="minPoolSize" value="${c3p0.minPoolSize}" />
        <property name="maxPoolSize" value="${c3p0.maxPoolSize}" />
        <property name="maxIdleTime" value="${c3p0.maxIdleTime}" />
        <property name="initialPoolSize" value="${c3p0.initialPoolSize}" />
        <property name="maxStatements" value="${c3p0.maxStatements}"></property>
        <property name="acquireIncrement" value="${c3p0.acquireIncrement}"></property>
        <property name="acquireRetryAttempts" value="${c3p0.acquireRetryAttempts}"></property>
        <property name="idleConnectionTestPeriod" value="${c3p0.idleConnectionTestPeriod}"></property>
        <property name="breakAfterAcquireFailure" value="${c3p0.breakAfterAcquireFailure}"></property>
        <property name="testConnectionOnCheckout" value="${c3p0.testConnectionOnCheckout}"></property>
    </bean>

       作用:配置C3P0数据源。  不论使用什么样的持久化技术,都必须通过数据连接访问数据库。在Spring中数据连接是通过数据源获得的。并且我们不仅可以使用JNDI获取应用服务器的数据源,也可以直接在Spring容器中配置数据源,此外还可以通过代码的方式创建数据源。Spring在第三方依赖包中包含了两个数据源的实现类包,①是Apache的DBCP;②是C3P0。

       6、代码:              

<!-- 用p6spy 在console显示变量绑定后的真实sql 与ResultSet,方便开发 -->
    <bean id="myP6DataSource" class="com.p6spy.engine.spy.P6DataSource">
        <constructor-arg>
            <ref local="c3p0DataSource" />
        </constructor-arg>
    </bean>

      作用:配置P6SPY,可以在控制台打印出真正 已经为变量赋值》的SQL语句, 方便我们在开发的过程中调试;但是在项目交付的时候需关掉。

       7、代码:

<!-- 配置SessionFactory -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource">
            <ref bean="myP6DataSource" />
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${hibernate.dialect}</prop>
                <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
                <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
                <!--
                    <prop
                    key="hibernate.jdbc.fetch_size">${hibernate.jdbc.fetch_size}</prop>
                -->
                <!--
                    <prop
                    key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop>
                -->
                <!--
                    <prop
                    key="hibernate.use_sql_comments">${hibernate.use_sql_comments}</prop>
                -->
                <!--
                    <prop
                    key="hibernate.connection.driver_class">${hibernate.connection.driver_class}</prop>
                -->
            </props>
        </property>
        <property name="mappingLocations">
            <list>
                <!-- 注意可以使用通配符 -->
                <value>classpath*:com/sse/*/domain/*.hbm.xml</value>
            </list>
        </property>
    </bean>

       作用:此处为Hibernate的SessionFactory配置代码。  

       8、代码:              

<!-- HibernateTemplate,数据层用的模板工具 -->
    <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>

       数据访问对象DAO作用是用来完成对数据库的操作,依赖的是SessionFactory对象;但是,此事的SessionFactory非彼时的SessionFactory,它已经被Spring管理起来了,所以DAO依赖的是Spring提供的SessionFactory,而不是Hibernate本身的SessionFactory。那么具体操作数据的方法是怎么实现的呢???没错,你想的没错,你不会告诉我你不知道吧。。。好吧!其实是Spring对Hibernate也提供模板支持 org.springframework.orm.hibernate3.HibernateTemplate),我们可以使用模板来简化我们的开发过程。你会不会疑问我到底怎么用模板呢?Spring给我们提供了一个模板的封装类(org.springframework.orm.hibernate3.support. HibernateDaoSupport)。我们在代码中通过  getHibernateTemplate()就可以得到模板,然后我们再使用模板提供给我们的方法来操作数据。例如:getHibernateTemplate().save(transientInstance);

       9、代码:              

<!-- 配置事物管理器,即:以下的的事务管理器由sessionFactory创建的session进行管理 -->
    <bean id="transactionManager"
        class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>
    <!-- 配置advice事物传播特性-->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT" />
            <tx:method name="update*" propagation="REQUIRED" isolation="DEFAULT" />
            <tx:method name="delete**" propagation="REQUIRED"
                isolation="DEFAULT" />
            <tx:method name="get*" propagation="REQUIRED" isolation="DEFAULT"
                read-only="true" />
            <tx:method name="find*" propagation="REQUIRED" isolation="DEFAULT"
                read-only="true" />
            <tx:method name="*" propagation="REQUIRED" isolation="DEFAULT" />
        </tx:attributes>
    </tx:advice>
    <!-- 事务管理器应用范围,切面配置 -->
    <aop:config>
        <aop:pointcut id="transactionPointcut" expression="execution(* com.sse.*.service.*.*(..))" />
        <aop:advisor advice-ref="txAdvice" pointcut-ref="transactionPointcut" />
    </aop:config>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值