JavaEE框架---Spring第四部分(SSH整合)


                           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。
    • 映射文件
  • 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配置一个过滤器:

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值