我们使用Spring中的HibernateTemplate进行数据的操作,其中的配置如下:
在applicationContext.xml文件中配置:
<!-- 配置HibernateTemplate -->
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<bean id="categoryService" class="com.shop.service.impl.CategoryServiceImpl">
<property name="ht" ref=""hibernateTemplate""></property>
</bean>
service层:
package com.shop.service.impl;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import com.shop.pojo.Category;
import com.shop.service.CategoryService;
public class CategoryServiceImpl implements CategoryService {
private HibernateTemplate ht;
public void setHt(HibernateTemplate ht) {
this.ht = ht;
}
// private SessionFactory sessionFactory;
// public void setSessionFactory(SessionFactory sessionFactory) {
// this.sessionFactory = sessionFactory;
// }
public void save(Category category) {
ht.save(category);
//Session session=sessionFactory.getCurrentSession();//得到当前线程的sessionFactory
//session.save(category);
}
}
但是在Spring4.0之后没有了HibernateTemplate,因此我们还是使用SessionFacoy:在applicationContext配置如下:
<bean id="categoryService" class="com.shop.service.impl.CategoryServiceImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
Service层:
package com.shop.service.impl;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import com.shop.pojo.Category;
import com.shop.service.CategoryService;
public class CategoryServiceImpl implements CategoryService {
//private HibernateTemplate ht;
// public void setHt(HibernateTemplate ht) {
// this.ht = ht;
// }
private SessionFactory sessionFactory;
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public void save(Category category) {
//ht.save(category);
Session session=sessionFactory.getCurrentSession();//得到当前线程的sessionFactory
session.save(category);
}
}
这里的sessionFactory实现FactoryBean<?>接口 ,在spring4.0之后没有HibernateTemplate,而且 HibernateTemplate也是基于FactorBeany实现,但是实质还是sessionFactory,所以使用HibernateTemplate也是多余,我们完全可以使用sessionFactory进行数据操作通过session.getCurrentSession()。
接下来介绍通过注解的形式得到bean以及bean之间的依赖等,因为如果我们把每个bean都在spring中的配置文件配置的话,就会出现多个bean,因而我们可以使用注解来简化bean的配置。
注释掉applicationContext.xml中的bean:添加启用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:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
">
<!-- 添加注解扫描器,启动的时候扫描指定包下的所有类文件是否注解 -->
<context:component-scan base-package="com.shop.."></context:component-scan>
<bean id="date" class="java.util.Date"></bean>
<!-- 这里的sessionFactory实现FactoryBean<?>接口 ,在spring4.0之后没有HibernateTemplate,而且 HibernateTemplate也是基于sessionFactory实现
所以使用HibernateTemplate也是多余,我们完全可以使用sessionFactory进行数据操作通过session.getCurrentSession();
--><!--
<bean id="categoryService" class="com.shop.service.impl.CategoryServiceImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>-->
<!-- <bean id="categoryService" class="com.shop.service.impl.CategoryServiceImpl">
<property name="ht" ref=""hibernateTemplate""></property>
</bean> -->
<!--<bean id="categoryAction" class="com.shop.action.CategoryAction" scope="prototype">
<property name="categoryService" ref="categoryService"></property>
</bean>-->
</beans>
Service层中的配置:
package com.shop.service.impl;
import javax.annotation.Resource;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.stereotype.Service;
import com.shop.pojo.Category;
import com.shop.service.CategoryService;
@Service(value="categoryService")//没有指定value的话,默认是第一个字母小写的类名,可以看做是xml中的bean的id
public class CategoryServiceImpl implements CategoryService {
//private HibernateTemplate ht;
// public void setHt(HibernateTemplate ht) {
// this.ht = ht;
// }
/*sessionFactory注解的名称,依赖于applicationContext.xml的 哇sessionFactoryBean,可以看做是xml中的ref,没有指定name的话,默认是属性名,
也可以放在set方法之前,但是使用注解,这里的set方法就省略掉*/
@Resource(name="sessionFactory")
private SessionFactory sessionFactory;
// public void setSessionFactory(SessionFactory sessionFactory) {
// this.sessionFactory = sessionFactory;
// }
public void save(Category category) {
//ht.save(category);
Session session=sessionFactory.getCurrentSession();//得到当前线程的sessionFactory
session.save(category);
}
}
Action层的配置:
package com.shop.action;
import javax.annotation.Resource;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;
import com.opensymphony.xwork2.ActionSupport;
import com.shop.pojo.Category;
import com.shop.service.CategoryService;
@Controller(value="categoryAction")
@Scope(value="prototype")
public class CategoryAction extends ActionSupport {
@Resource(name="categoryService")//可以看做是xml中的bean的ref,依赖于Service层中的categoryService
private CategoryService categoryService=null;
private Category category;
public void setCategory(Category category) {
this.category = category;
}
public Category getCategory() {
return category;
}
public void setCategoryService(CategoryService categoryService) {
this.categoryService = categoryService;
}
public void save() {
// TODO Auto-generated method stub
System.out.println("save方法:"+category.getType()+","+category.getHot());
categoryService.save(category);
}
}
接下来进行测试:
private static AbstractApplicationContext ac;
@Test
public void test03(){
//这里不能用实现类进行转换,否则会报类型转换异常
//因为如果类没有实现接口就通过CGLIB生成动态代理Proxy,有实现接口就通过Proxy生成代理对象
CategoryService categoryService= (CategoryService) ac.getBean("categoryService");
Category category=new Category("男士休闲3", true);
categoryService.save(category);
}
测试结果:
log4j:WARN No appenders could be found for logger (org.springframework.context.support.ClassPathXmlApplicationContext).
log4j:WARN Please initialize the log4j system properly.
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Hibernate: insert into shop.category (type, hot) values (?, ?)