• SSH 整合及注意事项


    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

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

  • 相关阅读:
    urllib3使用池管理发送请求和requests常用方法的基本使用+session使用
    Ajax爬取动态数据和HTTPS自动默认证书
    urllib库中的URL编码解码和GETPOST请求
    urllib的使用和进阶——urllib.request
    1.8学习进度总结
    1.7学习进度总结
    1.5学习进度总结
    1.4学习进度总结
    第十二周周进度总结
    第十一周周进度总结
  • 原文地址:https://www.cnblogs.com/xifenglou/p/5439330.html
Copyright © 2020-2023  润新知