码迷,mamicode.com
首页 > 其他好文 > 详细

SSH 整合及注意事项

时间:2016-04-27 16:59:30      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

Spring 整合 hibernate 配置

1. spring 配置管理datasource 及 sessionFactory

1) 引入相关jdbc配置文件。

 <context:property-placeholder location="classpath:jdbc.properties" />    

2) 配置datasource

<bean id="dataSourceUser" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${user.jdbc.driver}" />
        <property name="jdbcUrl" value="${user.jdbc.url}" />
        <property name="user" value="${user.jdbc.user}" />
        <property name="password" value="${user.jdbc.password}" />
        <!--连接池中保留的最大连接数。默认值: 15 -->   
          <property name="maxPoolSize" value="500"/>  
          <!-- 连接池中保留的最小连接数,默认为:3-->  
          <property name="minPoolSize" value="2"/>  
          <!-- 初始化连接池中的连接数,取值应在minPoolSize与maxPoolSize之间,默认为3-->  
          <property name="initialPoolSize" value="2"/> 
          <!--如果为false,则获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常,但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。默认: false-->   
          <property name="breakAfterAcquireFailure" value="false"/>  
 
          <!--每60秒检查所有连接池中的空闲连接。默认值: 0,不检查 -->   
          <property name="idleConnectionTestPeriod" value="60"/>  
          <!--c3p0全局的PreparedStatements缓存的大小。如果maxStatements与maxStatementsPerConnection均为0,则缓存不生效,只要有一个不为0,则语句的缓存就能生效。如果默认值: 0-->   
          <property name="maxStatements" value="100"/>  
          <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。默认值: 0 -->   
          <property name="maxStatementsPerConnection" value="0"/>  

    <!--  ...  -->
    </bean>

3) 配置sessionFactory
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <!-- 注入连接池 -->
        <property name="dataSource" ref="dataSource" />    <!--可由
        <!-- 配置Hibernate的其他的属性 -->
        <property name="hibernateProperties">
            <props>
                <!-- <prop key="current_session_context_class">thread</prop><prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> -->
                <prop key="hibernate.dialect">org.shenyundata.cn.base.BlobMySQLDialect</prop>
                <prop key="hibernate.show_sql">false</prop>
                <prop key="hibernate.format_sql">false</prop>

      <!--  ...  -->
            </props>
        </property>
        <!-- 配置映射的注解的实体类的包 -->
         <property name="packagesToScan">
            <list>
                <value>org.shenyundata.cn.model</value>
            </list>  
        </property>
    </bean>

4. 如果使用hibernateTemplate, 需要相关配置

<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>

5. 事务管理器 相关配置

    <bean id="transactionManager"
        class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>

6. 事务管理器的切面逻辑配置

<tx:advice id="advice" transaction-manager="transactionManager">
        <!-- 配置拦截 -->
        <tx:attributes>
            <tx:method name="get*" />
            <tx:method name="*" rollback-for="Throwable"  />
        </tx:attributes>
    </tx:advice>
   
    <!-- 配置拦截规则 -->
    <aop:config>
        <!-- 拦截规则 -->
        <aop:pointcut id="myPointcut"
            expression="execution(* org.***.cn.service.*.*(..)) or execution (* org.***.cn.task.*.*(..))  " />
        <aop:advisor advice-ref="advice" pointcut-ref="myPointcut" />
    </aop:config>

 

注意事项

1.spring 负责 管理service 及dao 的生成。

2.action的生成 由struts2 spring 的plugin生成,不受spring 的管理。

3. OpenSessionInviewFilter 注意事项:

1).  必须配置在struts2 filter前面。

2).  Filter 需要 sessionfactory bean,如果需要改名 需要在filter配置信息中加入  param-name: sessionfactorybeanname param-value

3).  如果不配置 transaction,会出异常  InvaliddataaccessapiUsageException write operations are not allowed **** readonly, 所以记得配置好事务管理器

 

7. 相关annotation 配置

<context:annotation-config />
    <!-- scanning package -->
<context:component-scan base-package="com.****" />

8.如果需要使用aspectj语法,定义切面类逻辑,需要下面的配置

<aop:aspectj-autoproxy />  AOP annotation语法支持 ,不太重要

AOP xml配置 (重要)  见第6点。     

附相关jar包:

数据库包及 日志的jar包会根据各公司的情况 略有不同。

Struts.2.1.6                    Spring 2.5.6   hibernate3.3.2           整合

Antlr-2.7.6.jar

AspectJ.jar

Aspectjweaver.jar

Cglib-nodep-2.1.3.jar

Common-annotations.jar

Commons-collections-3.1.jar

Commons-fileupload-1.2.1.jar

Commons-io-1.3.2.jar

Commons-logging-1.1.1.jar

Dom4j-1.6.1.jar

Ejb3-persistence.jar

Freeemarker-2.3.13.jar

Hibernate3.jar

Hibernate-annotations.jar

Hibernate-common-annotations.jar

Javaassist-3.9.0.GA.jar

Jta-1.1.jar

Junit4.5.jar

Mysql 驱动包

Ognl-2.6.11.jar

Slf4j-api-1.5.8.jar

Slf4j-nop-1.5.8.jar

Spring.jar

Struts2-core-2.1.6.jar

Xwork-2.1.2.jar

Commons-dbcp.jar

Commons-pool.jar

Struts-spring-plugin2.1.6.jar

 

个人整理,如有错误,欢迎各位留言告知,谢谢!

SSH 整合及注意事项

标签:

原文地址:http://www.cnblogs.com/xifenglou/p/5439330.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!