首先,目录结构大致如下:
Dao:
@Repository
public class UserDaoImpl extends HibernateDaoSupport implements UserDao {
/**
* 注入设置sessionFactory
*/
@Autowired
public void setSessionFacotry(SessionFactory sessionFacotry) {
super.setSessionFactory(sessionFacotry);
}
/**
* 根据用户名查询用户
*/
public User findUserByUserCode(String userCode) {
return super.getHibernateTemplate().execute(
new HibernateCallback<User>() {
public User doInHibernate(Session session)
throws HibernateException {
String hql = "from User where user_code=?";
Query query = session.createQuery(hql);
query.setParameter(0, userCode);
return (User) query.uniqueResult();
}
});
}
@Override
public void insertUser(User user) {
super.getHibernateTemplate().save(user);
}
}
Service:
@Service
public class UserServiceImpl implements UserService{
@Autowired
private UserDao userDao;
/**
* 用户登录
*/
public User userLogin(User user) {
User queryUser = userDao.findUserByUserCode(user.getUser_code());
if(queryUser == null) {
throw new RuntimeException("用户不存在");
}
if(!queryUser.getUser_password().equals(user.getUser_password())) {
throw new RuntimeException("密码错误");
}
return queryUser;
}
/**
* 用户注册
*/
@Transactional(isolation=Isolation.REPEATABLE_READ,propagation=Propagation.REQUIRED,readOnly=false)
public void userRegister(User user) {
userDao.insertUser(user);
}
}
Action:
@Controller
@Scope("prototype")
public class UserAction extends ActionSupport implements ModelDriven<User> {
private User user = new User();
@Override
public User getModel() {
return user;
}
@Autowired
private UserService userService;
public String login() {
User queryUser = userService.userLogin(user);
ActionContext.getContext().getSession().put("user", queryUser);
return "toHome";
}
}
db.propoerties:
jdbc.jdbcUrl=jdbc:mysql:///hibernate_32
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=root
applicationContext.xml:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans" 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-4.2.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsd ">
<!-- 注解驱动 -->
<context:component-scan base-package="com.bjfu"></context:component-scan>
<context:property-placeholder location="classpath:db.properties" />
<bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
<!-- 配置session工厂 -->
<bean name="sessionFactory"
class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<!-- 将连接池注入到sessionFactory中 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 基本配置 -->
<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>
<!-- 引入ORM元数据 -->
<property name="mappingDirectoryLocations">
<list>
<value>classpath:com/bjfu/domain</value>
</list>
</property>
</bean>
<!-- 配置核心事务管理器 -->
<bean name="transactionManager"
class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 开启注解事务 -->
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>
struts.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!-- Spring管理Struts -->
<constant name="struts.objectFactory" value="spring"></constant>
<package name="user" namespace="/" extends="struts-default">
<!-- 全局异常处理 -->
<global-exception-mappings>
<exception-mapping result="error" exception="java.lang.RuntimeException"></exception-mapping>
</global-exception-mappings>
<action name="userAction_*" class="userAction" method="{1}">
<result name="toHome" type="redirect">/index.htm</result>
<result name="error">/login.jsp</result>
</action>
</package>
</struts>
web.xml:
<!-- 让spring随web启动而创建的监听器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 配置spring配置文件位置参数 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- 扩大session作用范围 -->
<filter>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate5.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- struts2核心过滤器 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>