SSH导入所需jar依赖和hibernate的整合(1)

这篇博客介绍了如何在SSH框架中整合Hibernate5.2.12.Final,详细列出了所需的jar依赖,包括hibernate-core、c3p0、ehcache和mysql-connector-java等。还提到了Spring5.0.1.RELEASE的相关依赖,如spring-context、spring-orm等。此外,讲解了SSH集成步骤,如导入ehcache.xml、配置c3p0连接池、设置SessionFactory和事务管理器,以及自动代理的配置和原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. pom
    1.1 hibernate相关(5.2.12.Final)
    hibernate-core
    hibernate-c3p0(数据库连接池)
    hibernate-ehcache
    mysql-connector-java(5.1.44)

1.2 spring相关(5.0.1.RELEASE)
spring-context
spring-orm
spring-web
spring-aspects

  注:创建spring的XML文件时,需要添加beans/aop/tx/context标签支持

  各依赖说明:
  spring-context
    创建spring上下文

  spring-orm
    org.springframework.orm.hibernate5.LocalSessionFactoryBean
      dataSource:指定数据源
      hibernateProperties:指定hibernate相关属性,如:dialect/show_sql/format_sql 
      mappingResources:指定实体映射文件 
      注1:本章采用将hibernate配置全部交给spring管理,因此项目中不再有hibernate.cfg.xml文件
    org.springframework.orm.hibernate5.HibernateTemplate
    org.springframework.orm.hibernate5.support.HibernateDaoSupport
  测试一:运行测试类Test1,测试hibernate与spring的集成

  spring-web
    org.springframework.web.context.ContextLoaderListener
      contextConfigLocation:classpath:applicationContext-*.xml
    org.springframework.web.context.support.WebApplicationContextUtils
  测试二:访问test2.jsp,测试spring与WEB项目的集成

  spring-aspects
    spring的AspectJ依赖,解析事务切点

1.7 jsp自定义标签依赖(必须与tomcat的版本一致)
tomcat-jsp-api

  1. SSH集成
    2.1 导入ehcache.xml
    2.2 导入log4j2.xml
    2.3 集成hibernate
    2.3.1 注入数据库配置文件
    2.3.2 配置c3p0连接池
    2.3.3 注册LocalSessionFactoryBean
    2.3.4 spring声明式事物

     声明式事务配置
    
    1. 必须先修改spring配置文件的声明部分,添加对aop标签和tx标签的支持

    2. 配置SessionFactory(spring和hibernate集成时已完成)

    3. 配置事务管理器
      HibernateTransactionManager

    4. 配置事务的传播特性(tx)
      add
      edit
      del
      load|list
      事务传播特性(PROPAGATION_REQUIRED|readOnly)

    5. 配置自动代理
      a) 引用环绕通知txAdvice
      b) 定义一个切入点
      execution(* *…Biz.(…))
      a:返回值不限 b:包名不限 c:接口名以Biz结尾 d:方法名及参数不限
      c) 自动代理的原理
      在spring上下文初始化完成以后,自动代理会逐个检查spring上下文中JavaBean实现的接口是否满足自动代理的条件,如果满足条件,则将此bean和通知结合生成一个代理对象,并以此代理对象替换spring上下文中的bean,之后你访问的就是代理对象了

      注1:狸猫换太子

    2.3.5 注册HibernateTemplate
    2.3.6 注册Base模块

pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.xxx</groupId>
	<artifactId>Test_SSH</artifactId>
	<packaging>war</packaging>
	<version>0.0.1-SNAPSHOT</version>
	<name>Test_SSH Maven Webapp</name>
	<url>http://maven.apache.org</url>

	<properties>
		<hibernate.version>5.2.12.Final</hibernate.version>
		<mysql.version>5.1.44</mysql.version>
		<spring.version>5.0.1.RELEASE</spring.version>
		<struts2.version>2.5.13</struts2.version>
		<slf4j.version>1.7.7</slf4j.version>
		<log4j.version>2.9.1</log4j.version>
		<disruptor.version>3.2.0</disruptor.version>
		<junit.version>4.12</junit.version>
		<servlet.version>4.0.0</servlet.version>
		<jstl.version>1.2</jstl.version>
		<standard.version>1.1.2</standard.version>
		<tomcat-jsp-api.version>8.0.47</tomcat-jsp-api.version> <!-- tomcat-jsp-api.version必须是跟你的tomcat版本相对应的 -->
	</properties>
	<dependencies>
		<!-- 1、hibernate相关(5.2.12.Final) -->
		<dependency>
			<groupId>org.hibernate</groupId>
			<artifactId>hibernate-core</artifactId>
			<version>${hibernate.version}</version>
		</dependency>

		<dependency>
			<groupId>org.hibernate</groupId>
			<artifactId>hibernate-c3p0</artifactId>
			<version>${hibernate.version}</version>
		</dependency>

		<dependency>
			<groupId>org.hibernate</groupId>
			<artifactId>hibernate-ehcache</artifactId>
			<version>${hibernate.version}</version>
		</dependency>

		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>${mysql.version}</version>
		</dependency>
		
		<!-- 2、spring相关(5.0.1.RELEASE) -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context</artifactId>
			<version>${spring.version}</version>
		</dependency>

		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-orm</artifactId>
			<version>${spring.version}</version>
		</dependency>

		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-web</artifactId>
			<version>${spring.version}</version>
		</dependency>

		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-aspects</artifactId>
			<version>${spring.version}</version>
		</dependency>
		<!-- 3、struts2相关(2.5.13) -->
		<dependency>
			<groupId>org.apache.struts</groupId>
			<artifactId>struts2-core</artifactId>
			<version>${struts2.version}</version>
		</dependency>

		<dependency>
			<groupId>org.apache.struts</groupId>
			<artifactId>struts2-spring-plugin</artifactId>
			<version>${struts2.version}</version>
		</dependency>
		
		<!-- 4、log配置 -->
		<!-- log配置:Log4j2 + Slf4j -->
		<!-- slf4j核心包 -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>${slf4j.version}</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>jcl-over-slf4j</artifactId>
			<version>${slf4j.version}</version>
			<scope>runtime</scope>
		</dependency>

		<!--用于与slf4j保持桥接 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-slf4j-impl</artifactId>
			<version>${log4j.version}</version>
		</dependency>

		<!--核心log4j2jar包 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-api</artifactId>
			<version>${log4j.version}</version>
		</dependency>
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-core</artifactId>
			<version>${log4j.version}</version>
		</dependency>
		
		<!--web工程需要包含log4j-web,非web工程不需要 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-web</artifactId>
			<version>${log4j.version}</version>
			<scope>runtime</scope>
		</dependency>
		<!--需要使用log4j2的AsyncLogger需要包含disruptor -->
		<dependency>
			<groupId>com.lmax</groupId>
			<artifactId>disruptor</artifactId>
			<version>${disruptor.version}</version>
		</dependency>
		
		<!-- 5、other -->
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>${junit.version}</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>javax.servlet-api</artifactId>
			<version>${servlet.version}</version>
			<scope>provided</scope>
		</dependency>
		
		<dependency>
			<groupId>jstl</groupId>
			<artifactId>jstl</artifactId>
			<version>${jstl.version}</version>
		</dependency>
		<dependency>
			<groupId>taglibs</groupId>
			<artifactId>standard</artifactId>
			<version>${standard.version}</version>
		</dependency>
		
		<dependency>
			<groupId>org.apache.tomcat</groupId>
			<artifactId>tomcat-jsp-api</artifactId>
			<version>${tomcat-jsp-api.version}</version>
		</dependency>
		

	</dependencies>
	<build>
		<finalName>Test_SSH</finalName>
		<plugins>
			<!--第一步就是配置maven-compiler-plugin插件 -->
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>3.7.0</version>
				<configuration>
					<source>1.8</source>
					<target>1.8</target>
					<encoding>UTF-8</encoding>
				</configuration>
			</plugin>
		</plugins>
	</build>
</project>

db.properties(链接数据库):

	db.username=root
	db.password=123
	db.driverClass=com.mysql.jdbc.Driver
	db.jdbcUrl=jdbc:mysql://127.0.0.1:3306/bookshop?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT
	db.initialPoolSize=10
	db.maxPoolSize=20
	db.minPoolSize=5
	db.maxIdleTime=60
	db.acquireIncrement=5
	db.maxStatements=0
	db.idleConnectionTestPeriod=60
	db.acquireRetryAttempts=30
	db.breakAfterAcquireFailure=true
	db.testConnectionOnCheckout=false

spring-context.xml:

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

	<import resource="classpath:spring-hibernate.xml"/>
	<import resource="classpath:spring-book.xml"/>
</beans>

spring-hibernate.xml:

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

<!-- 1、注册jdbc相关的配置文件 -->
<context:property-placeholder location="classpath:db.properties"/>
<!-- 2、配置数据库连接池C3P0 -->
	<!-- 注册数据库连接文件db.properties -->
	<context:property-placeholder location="classpath:db.properties" />
		
	<!-- 配置c3p0连接池 -->
	<bean id="dataSource"
		class="com.mchange.v2.c3p0.ComboPooledDataSource">
			<property name="user" value="${db.username}"></property>
			<property name="password" value="${db.password}"></property>
			<property name="driverClass" value="${db.driverClass}"></property>
			<property name="jdbcUrl" value="${db.jdbcUrl}"></property>
	
			<!--初始化时获取的连接数,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
			<property name="initialPoolSize"
				value="${db.initialPoolSize}"></property>
			<!--连接池中保留的最大连接数。Default: 15 -->
			<property name="maxPoolSize" value="${db.maxPoolSize}"></property>
			<!--连接池中保留的最小连接数。 -->
			<property name="minPoolSize" value="${db.minPoolSize}" />
			<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
			<property name="maxIdleTime" value="${db.maxIdleTime}" />
	
			<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
			<property name="acquireIncrement" value="${db.acquireIncrement}" />
	
			<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements 属于单个connection而不是整个连接池。 
				所以设置这个参数需要考虑到多方面的因素。如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 
				0 -->
			<property name="maxStatements" value="${db.maxStatements}" />
	
			<!--每60秒检查所有连接池中的空闲连接。Default: 0 -->
			<property name="idleConnectionTestPeriod" value="${db.idleConnectionTestPeriod}" />
	
			<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
			<property name="acquireRetryAttempts" value="${db.acquireRetryAttempts}" />
	
			<!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效 保留,并在下次调用getConnection()的时候继续尝试获取连接。 
				如果设为true,那么在尝试 获取连接失败后该数据源将申明已断开并永久关闭。Default: false -->
			<property name="breakAfterAcquireFailure" value="${db.breakAfterAcquireFailure}" />
	
			<!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的 时候都将校验其有效性。建议使用idleConnectionTestPeriod 
				或automaticTestTable 等方法来提升连接测试的性能。Default: false -->
			<property name="testConnectionOnCheckout" value="${db.breakAfterAcquireFailure}" />
		</bean>
		
		
<!-- 3、配置sessionfactory相关信息 -->
		<bean id="sessionFactory"
		class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
		<!-- 数据源 -->
		<property name="dataSource">
			<ref bean="dataSource" />
		</property>
		<!-- hibernate相关属性 -->
		<property name="hibernateProperties">
			<props>
				<prop key="dialect">org.hibernate.dialect.MySQLDialect</prop>
                <!--spring与Hibernate集成无法显示sql语句问题,请见集成后hibernate无法显示sql语句.txt-->
				<prop key="hibernate.show_sql">true</prop>
				<prop key="hibernate.format_sql">true</prop>
			</props>
		</property>
		<!-- 实体映射文件 -->
		<property name="mappingResources">
			<list>
				<value>com/book/entity/Book.hbm.xml</value>
			</list>
		</property>
	</bean>
	
	
<!-- 4、配置事务 -->
	<!--声明式事务配置开始 -->
	<!-- 
		静态代理:
				一个代理对象->一个目标对象
				BookPeoxy(BookBizImpl+myMethodBeforeAdvice)->bookBiz
				OrderPeoxy(OrderBizImpl+myMethodBeforeAdvice)->	OrderBiz
	 	动态代理:
	 			一个代理对象——>多个目标对象
	 
	 -->
	<!--1) 开启自动代理 -->
	<aop:aspectj-autoproxy />

	<!--2) 事务管理器 -->
	<bean id="transactionManager"
		class="org.springframework.orm.hibernate5.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>

	<!--3) 定义事务特性 -->
	<tx:advice id="txAdvice"
		transaction-manager="transactionManager">
		<tx:attributes>
			<tx:method name="add*" propagation="REQUIRED" />
			<tx:method name="save*" propagation="REQUIRED" />
			<tx:method name="insert*" propagation="REQUIRED" />

			<tx:method name="edit*" propagation="REQUIRED" />
			<tx:method name="update*" propagation="REQUIRED" />

			<tx:method name="del*" propagation="REQUIRED" />
			<tx:method name="remove*" propagation="REQUIRED" />

			<tx:method name="load*" propagation="REQUIRED" read-only="true" />
			<tx:method name="list*" propagation="REQUIRED" read-only="true" />
			<tx:method name="select*" propagation="REQUIRED" read-only="true" />
			<tx:method name="query*" propagation="REQUIRED" read-only="true" />

			<tx:method name="do*" propagation="REQUIRED" />
		</tx:attributes>
	</tx:advice>

	<!--4) 定义切入点 -->
	<aop:config>
		<!-- pointcut属性用来定义一个切入点,分成四个部分理解 [* ][*..][*Biz][.*(..)] -->
		<!-- A: 返回类型,*表示返回类型不限 -->
		<!-- B: 包名,*..表示包名不限 -->
		<!-- C: 类或接口名,*Biz表示类或接口必须以Biz结尾 -->
		<!-- D: 方法名和参数,*(..)表示方法名不限,参数类型和个数不限 -->
		<aop:advisor advice-ref="txAdvice"
			pointcut="execution(* *..*Biz.*(..))" />
	</aop:config>
	<!-- 声明式事务配置结束 -->


<!-- 5、配置HibernateTemplate -->
<bean class="org.springframework.orm.hibernate5.HibernateTemplate" id="hibernateTemplate">
	<property name="sessionFactory" ref="sessionFactory"></property>
</bean>

<!-- 6、分模块开发(只配置base模块) -->
<bean class="com.base.entity.BaseEntity" abstract="true" id="baseEntity"></bean>
<bean class="com.base.dao.BaseDao" abstract="true" id="baseDao">
	<property name="hibernateTemplate" ref="hibernateTemplate"></property>
</bean>
<bean class="com.base.biz.BaseBiz" abstract="true" id="baseBiz"></bean>
<bean class="com.base.web.BaseAction" abstract="true" id="baseAction"></bean>

(注意看下一章,分开写的!这章只讲了导jar包和hibernate的整合。)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值