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 整合及注意事项的更多相关文章

  1. 【Java EE 学习 67 下】【OA项目练习】【SSH整合JBPM工作流】【JBPM项目实战】

    一.SSH整合JBPM JBPM基础见http://www.cnblogs.com/kuangdaoyizhimei/p/4981551.html 现在将要实现SSH和JBPM的整合. 1.添加jar ...

  2. Spring自学教程-ssh整合(六)

    以下是本人原创,如若转载和使用请注明转载地址.本博客信息切勿用于商业,可以个人使用,若喜欢我的博客,请关注我,谢谢!博客地址 感谢您支持我的博客,我的动力是您的支持和关注!如若转载和使用请注明转载地址 ...

  3. 三大框架SSH整合

    三大框架SSH整合 -------------------------------Spring整合Hibernate------------------------------- 一.为什么要整合Hi ...

  4. SSH整合(struts2.3.24+hibernate3.6.10+spring4.3.2+mysql5.5+myeclipse8.5+tomcat6+jdk1.6)

    终于开始了ssh的整合,虽然现在比较推崇的是,ssm(springmvc+spring+mybatis)这种框架搭配确实比ssh有吸引力,因为一方面springmvc本身就是遵循spring标准,所以 ...

  5. SSH整合之全注解

    SSH整合之全注解 使用注解配置,需要我们额外引入以下jar包

  6. 用ssh整合时,用sessionfactory的getCurrentSession()获取不到session

    在用ssh整合时,一开始用的是getCurrentSession(),获取当前线程上的session,但是总是抛异常,不能获取. 后来用sessionfactory的openSession(),但是, ...

  7. SSH整合(1)异常

    信息: No Spring WebApplicationInitializer types detected on classpath 十二月 01, 2016 10:06:12 下午 org.apa ...

  8. Spring(八)SSH整合简述

    一.Spring与Struts2的整合 1.1.整合步骤 1.2.配置web.xml 1.3.配置spring配置文件applicationContext.xml 1.4.配置struts配置文件 1 ...

  9. SSH整合之spring整合hibernate

    SSH整合要导入的jar包: MySQL中创建数据库 create database ssh_db; ssh_db 一.spring整合hibernate带有配置文件hibernate.cfg.xml ...

随机推荐

  1. (转载)Windows常见性能计数器(较好的说明)

    转载地址:http://blog.csdn.net/dfbrt56/article/details/3341591 Windows常见性能计数器 性能计数器(counter)是描述服务器或操作系统性能 ...

  2. 如何创建C# Closure ?

    JavaScript中一个重要的概念就是闭包,闭包在JavaScript中有大量的应用,但是你知道么?C#也可以创建Closure.下面就介绍一下如何在C#中创建神奇的闭包. 在这之前,我们必须先知道 ...

  3. Web 前沿——HTML5 Form Data 对象的使用

    XMLHttpRequest Level 2 添加了一个新的接口——FormData.利用 FormData 对象,我们可以通过 JavaScript 用一些键值对来模拟一系列表单控件,我们还可以使用 ...

  4. 简单代码在ABAP中实现声音的播放

    这段代码的功能是在SAP里面实现声音的播放,可以用作程序提醒功能,和SAP里面’噹噹噹’那个声音的意思差不多.将来在项目中遇到客户想要SAP ABAP发出一点声音的时候就可以参考一下这个程序. REP ...

  5. sqlmap笔记

    sqlmap -u "注入链接" --其他参数或命令 (-v 1表示回显出注入过程) [判断指定字段是否存在注入点]当链接包含两个参数时,可用-p开关选择要注入的参数,例检测id是 ...

  6. The specified file or folder name is too long

    You receive a "The specified file or folder name is too long" error message when you creat ...

  7. java使用动态代理来实现AOP(日志记录)

    以下内容为原创,转载时请注明链接地址:http://www.cnblogs.com/tiantianbyconan/p/3336627.html AOP(面向方面)的思想,就是把项目共同的那部分功能分 ...

  8. node.js Tools for Visual Studio 介绍

    node.js Tools for Visual Studio简称NTVS 项目 安装包地址:https://nodejstools.codeplex.com 目前支持2012和2013

  9. 单独编译Android系统模块并替换进系统

    例如,我修改了frameworks\base\policy\src\com\android\internal\policy\impl\PhoneWindowManager.java文件,进入frame ...

  10. 网站错误记录:A transport-level error has occurred when sending the request to the server.

    今天查看公司项目的日志文件,发现有这个错误:A transport-level error has occurred when sending the request to the server. 感 ...