1.2SSH整合方式一:无障碍整合
1.2.1SSH框架回顾
1.2.1.1SSH框架整合开发回顾
1.2.2SSH整合
1.2.2.1第一步:创建web项目,引入jar包
- Struts2的jar包
- struts-2.3.24\apps\struts2-blank\WEB-INF\lib\*.jar
- Struts2中有一些包需要了解的:
- struts2-convention-plugin-2.3.24.jar ----Struts2的注解开发包。
- struts2-json-plugin-2.3.24.jar ----Struts2的整合AJAX的开发包。
- struts2-spring-plugin-2.3.24.jar ----Struts2的整合Spring的开发包。
- Hibernate的jar包
- Hibernate的开发的必须的包
- hibernate-release-5.0.7.Final\lib\required\*.jar
- MySQL驱动
- mysql-connector-java-5.1.7-bin.jar
- 日志记录
- 使用C3P0连接池:
- *****注意:Struts2和Hibernate都引入了一个相同的jar包(javassist包)。删除一个******
- 因为struts2和hibernate都引入了日志记录的包,struts2的log4j-api-2.2.jar和log4j-core-2.2.jar可以删除,也可以不删除。
- Spring的jar包
- IOC的开发(四个基本jar包和日志记录)
- AOP的开发
- JDBC模板的开发
- 事务管理
- 整合web项目的开发
- 整合单元测试的开发
- 整合hibernate的开发
1.2.2.2第二步:引入配置文件
- Struts的配置文件
- web.xml
- struts.xml
- Hibernate的配置文件
- hibernate.cfg.xml
- 删除那个与线程绑定的session。
- 映射文件
- hibernate.cfg.xml
- Spring的配置文件
- web.xml
- applicationContext.xml
- 日志记录
- log4j.properties
1.2.2.3第三步:创建包结构
1.2.2.4第四步:创建相关类
1.2.2.5第五步:引入相关的页面
1.2.2.6第六步:修改add.jsp
1.2.2.7第七步:Spring整合Struts2方式一:Action由Struts2自身创建的。
- 编写Action
- 配置Action
- 在struts.xml中配置
- 在Action中引入Service
- 传统方式
- 进行Spring和Struts2的整合:
- 引入struts-spring-plugin.jar
- 在插件包中有如下配置
- 让Action按照名称自动注入Service:
- 将Service交给Spring管理
- Action注入Service
1.2.2.8第八步:Spring整合Struts2方式二:Action交给Spring管理(推荐)
- 引入插件包
- 引入struts-spring-plugin.jar
- 将Action交给Spring
- 在struts.xml中配置Action
- 注意:
- 需要配置Action为多例的:
- 需要手动注入Service
1.2.2.9第九步:Service调用DAO
- 将DAO交给Spring管理
- 在Service注入DAO
1.2.2.10第十步:Spring整合Hibernate框架
- 创建数据库和表
Create database ssh1;
Use ssh1;
CREATE TABLE `cst_customer` (
`cust_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '客户编号(主键)',
`cust_name` varchar(32) NOT NULL COMMENT '客户名称(公司名称)',
`cust_source` varchar(32) DEFAULT NULL COMMENT '客户信息来源',
`cust_industry` varchar(32) DEFAULT NULL COMMENT '客户所属行业',
`cust_level` varchar(32) DEFAULT NULL COMMENT '客户级别',
`cust_phone` varchar(64) DEFAULT NULL COMMENT '固定电话',
`cust_mobile` varchar(16) DEFAULT NULL COMMENT '移动电话',
PRIMARY KEY (`cust_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
- 编写实体和映射
- Spring和Hibernate整合
- 在Spring的配置文件中,引入Hibernate的配置的信息
- 在Spring和Hibernate整合后,Spring提供了一个Hibernate的模板类简化Hibernate开发。
- 改写DAO继承HibernateDaoSupport
- 配置的时候在DAO中直接注入SessionFactory
- 在DAO中使用Hibernate的模板完成保存操作
1.2.2.11第十一步:配置Spring的事务管理
- 配置事务管理器
- 开启注解事务
- 在业务层使用注解
1.3SSH整合方式二:将hibernate的配置交给Spring管理
1.3.1SSH整合方式二:不带hibernate配置文件
1.3.1.1复制一个项目
1.3.1.2hibernate配置文件中有哪些内容:
- 数据库连接的配置
- Hibernate的相关的属性的配置
- 方言
- 显示SQL
- 格式化SQL
- 。。。
- C3P0连接池
- 映射文件
1.3.1.3将Hibernate的配置交给Spring
<?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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
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/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 引入外部属性文件 -->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 配置C3P0连接池=============================== -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driverClass}"/>
<property name="jdbcUrl" value="${jdbc.url}"/>
<property name="user" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!-- Spring整合Hibernate -->
<!-- 引入Hibernate的配置的信息=============== -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<!-- 注入连接池 -->
<property name="dataSource" ref="dataSource"/>
<!-- 配置Hibernate的相关属性 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
<!-- 设置映射文件 -->
<property name="mappingResources">
<list>
<value>com/itheima/ssh/domain/Customer.hbm.xml</value>
</list>
</property>
</bean>
<!-- Service的配置 =============-->
<bean id="customerService" class="com.itheima.ssh.service.impl.CustomerServiceImpl">
<!-- 注入 Dao-->
<property name="customerDao" ref="customerDao"/>
</bean>
<!-- 用Spring管理Action============= -->
<bean id="customerAction" class="com.itheima.ssh.web.action.CustomerAction" scope="prototype">
<!-- 注入 Service-->
<property name="customerService" ref="customerService"/>
</bean>
<!-- 配置Dao================= -->
<bean id="customerDao" class="com.itheima.ssh.dao.impl.CustomerDaoImpl">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<!-- 配置事务管理器============= -->
<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<!-- 开启注解事务================== -->
<tx:annotation-driven transaction-manager="transactionManager"/>
</beans>
1.4Hibernate的模板的使用
1.4.1Hibernate模板的常用的方法
1.4.1.1保存操作
- save(Object obj);
1.4.1.2修改操作
- update(Object obj);
1.4.1.3删除操作
- delete(Object obj);
1.4.1.4查询操作
- 查询一个
- get(Class c,Serializable id);
- load(Class c,Serializable id);
- 查询多个
- List find(String hql,Object… args);
- List findByCriteria(DetachedCriteria dc);
- List findByCriteria(DetachedCriteria dc,int firstResult,int maxResults);
- List findByNamedQuery(String name,Object… args);
public class CustomerDaoImpl extends HibernateDaoSupport implements CustomerDao{
public void save(Customer customer) {
System.out.println("Dao save run ...");
this.getHibernateTemplate().save(customer);
}
public void update(Customer customer) {
this.getHibernateTemplate().update(customer);
}
public void delete(Customer customer) {
this.getHibernateTemplate().delete(customer);
}
public Customer findById(Long cust_id) {
return this.getHibernateTemplate().get(Customer.class, cust_id);
}
public List<Customer> findAllByHQL() {
List<Customer> list=(List<Customer>) this.getHibernateTemplate().find("from Customer");
return list;
}
//分页尽量用QBC
public List<Customer> findAllByQBC() {
DetachedCriteria criteria=DetachedCriteria.forClass(Customer.class);
List<Customer>list=(List<Customer>) this.getHibernateTemplate().findByCriteria(criteria);
return list;
}
//查询所有:命名查询
public List<Customer> findAllByNamedQuery() {
return (List<Customer>) this.getHibernateTemplate().findByNamedQuery("queryAll");
}
}
命名查询:在Customer.hbm.xml中设置
1.5延迟加载问题的解决
1.5.1Spring提供了延迟加载的解决方案
1.5.1.1在SSH整合开发中哪些地方会出现延迟加载
- 使用load方法查询某一个对象的时候(不常用)
- 查询到某个对象以后,显示其关联对象。
解决方法:
在web.xml配置一个过滤器: