spring与struts2整合就是将 Action对象交给spring容器负责
spring与Hibernate整合就是将 sessionFactory对象交给spring来负责维护,spring负责session维护以及aop事务
spring三大框架整合
1、导包:
hibernate包:
*hibernate/lib/required
*hibernate/lib/jpa|java的持久化规范(接口)
*数据库驱动
struts2包:
struts-blank.war/WEB-INF/lib/
注意:javassist-3.18.1-GA.jar与hibernate中的重复,删除版本低的
*struts2整合spring插件包(这个包一旦导入,struts2在启动时就会寻找spring容器,找不到就报错)
spring包:
*基本包4+2
core、beans、expression、logging、log4j
*整合web:web包
spring-web
*整合aop:4个包
spring-aop、spring-aspect、aop联盟、aopweaving
*整合jdbc事务4个包
spring-jdbc、spring-tx、c3p0、spring-orm
*整合junit4测试:test包
spring-test
标签库
standard.jar、jstl包
2、单独配置spring容器:
a.创建配置文件,并且导入约束(4个)beans、bean、aop、tx
b.配置web.xml文件spring随web启动而创建的监听器
org.springframework.web.context.ContextLoaderListener
contextConfigLocation
classpath:applictionContext.xml
3、单独配置struts2:
a.配置struts2主配置文件
/success.jsp
b.在web.xml配置核心过滤器
struts2
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
struts2
/*
4、struts2与spring整合
a.导包:struts2-spring-plugin-2.3.24.jar
b.配置常量
c、整合方案一:struts2自己创建action,spring负责组装依赖属性(不推荐:最好由spring完整管理action的生命周期,spring中的功能才能应用到action)
/success.jsp
d、整合方案二:spring负责创建action对象以及组装(重点)
//struts2.xml
/success.jsp
//applicationContext.xml
5、单独配置hibernate
a.导入实体类与ORM元数据
b.配置主配置文件(hibernate.cfg.xml)
com.mysql.jdbc.Driver
jdbc:mysql:///crm_32?useUnicode=true&characterEncoding=utf8
root
org.hibernate.dialect.MySQLDialect
true
true
update
6、整合spring与hibernate
a.整合原理:将sessionFactory对象交给spring容器管理
b.在spring中配置sessionFactory
配置方案一(了解):
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applictionContext.xml")
public class HibernateTest {
@Resource(name="sessionFactory")
private SessionFactory sf;
@Test
public void fun1(){
Session session = sf.openSession();
Transaction tx = session.beginTransaction();
//------------------------------
User u = new User();
u.setUser_code("jack");
u.setUser_name("杰克");
u.setUser_password("1234");
session.save(u);
//------------------------------
tx.commit();
session.close();
}
}
配置方案二(重要):
com.mysql.jdbc.Driver
jdbc:mysql:///crm_32?useUnicode=true&characterEncoding=utf8
root
org.hibernate.dialect.MySQLDialect
true
true
update
7、整合spring与c3p0连接池
a.配置db.properties:
jdbc.jdbcUrl=jdbc:mysql:///crm_32
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=
b.配置spring配置文件
true
true
update
8、spring整合hibernate环境操作数据库
a.Dao类创建:继承HibernateDaoSupport
public class UserDaoImpl extends HibernateDaoSupport implements UserDao
b.hibernate模板操作
execute:
public class UserDaoImpl extends HibernateDaoSupport implements UserDao {
@Override
public User getByUserCode(final String usercode) {
//HQL
return getHibernateTemplate().execute(new HibernateCallback() {
@Override
public User doInHibernate(Session session) throws HibernateException {
String hql = " from User where user_code = ?";
Query query = session.createQuery(hql);
query.setParameter(0, usercode);
User user = (User) query.uniqueResult();
return user;
}
});
findByCriteria:
public class UserDaoImpl extends HibernateDaoSupport implements UserDao {
@Override
public User getByUserCode(final String usercode) {
//Criteria
DetachedCriteria dc = DetachedCriteria.forClass(User.class);
dc.add(Restrictions.eq("user_code", usercode));
List list = (List) getHibernateTemplate().findByCriteria(dc);
if (list != null && list.size()>0) {
return list.get(0);
}else{
return null;
}
}
c. spring配置dao
9、spring的aop事务
a.准备工作配置核心事务管理器
b.xml配置aop事务
c.注解配置aop事务
service类中使用注解
@Transactional(isolation=Isolation.REPEATABLE_READ,propagation=Propagation.REQUIRED,readOnly=true)
public class UserServiceImpl implements UserService{
private UserDao ud;
@Override
public User getUserByCodePassword() {
System.out.println("getUserByCodePassword");
return null;
}
@Override
@Transactional(isolation=Isolation.REPEATABLE_READ,propagation=Propagation.REQUIRED,readOnly=false)
public void saveUser(User u) {
ud.save(u);
}
public void setUd(UserDao ud) {
this.ud = ud;
}
}
10、扩大session作用范围
为了避免使用懒加载时出现no-session问题,需要扩大session的范围
a.配置filter
openSessionInView
org.springframework.orm.hibernate5.support.OpenSessionInViewFilter
openSessionInView
/*