spring(5):spring,struts2和hibernate结合

本节主要通过一个小例子来讲解spring,struts,hibernate的结合:

 

例:增删改查用户:

操作列表:保存用户或显示所有用户,如下图

 

新增用户界面

 

显示所有用户列表

修改用户:

 

 

以下是代码实现,此工程所需的JAR包及配置与前几节一样

User对应的bean,user有id,age,firstname,lastname四个属性:

package com.test.bean;

public class User {
	private int id;
	private int age;
	private String firstname;
	private String lastname;
	
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public String getFirstname() {
		return firstname;
	}
	public void setFirstname(String firstname) {
		this.firstname = firstname;
	}
	public String getLastname() {
		return lastname;
	}
	public void setLastname(String lastname) {
		this.lastname = lastname;
	}
}

 

User对应的hibernate配置文件

User.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC    
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.test.bean.User" table="users">
		<id name="id" column="id" type="int">
			<generator class="increment"></generator>
		</id>
		<property name="firstname" column="firstname" type="java.lang.String"></property>
		<property name="lastname" column="lastname" type="java.lang.String"></property>
		<property name="age" column="age" type="int"></property>
	</class>
</hibernate-mapping>

 

其对应的dao接口

UserDAO.java

package com.test.dao;

import java.util.List;

import com.test.bean.User;

public interface UserDAO {
	public void saveUser(User user);
	public List<User> findAllUsers();
	public void removeUser(User user);
	public void updateUser(User user);
	public User findUserById(Integer id);
}

 

 

实现类UserDAOImpl.java

 

package com.test.dao.impl;

import java.util.List;

import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import com.test.bean.User;
import com.test.dao.UserDAO;

public class UserDAOImpl extends HibernateDaoSupport implements UserDAO{
	public void saveUser(User user) {
		this.getHibernateTemplate().save(user);
	}
	public List<User> findAllUsers() {
		String hql = " from User user order by user.id desc";
		return (List<User>)this.getHibernateTemplate().find(hql);
	}
	public void removeUser(User user) {
		this.getHibernateTemplate().delete(user);
	}
	public User findUserById(Integer id) {
		User user = (User) this.getHibernateTemplate().get(User.class, id);
		return user;
	}
	public void updateUser(User user) {
		this.getHibernateTemplate().update(user);
	}
}

 

UserService.java接口

package com.test.service;

import java.util.List;
import com.test.bean.User;

public interface UserService {
	public void save(User user);
	public List<User> findAll();
	public void delete(User user);
	public void update(User user);
	public User findById(Integer id);
}

 

实现类,通过调用 DAO层代码,分别实现用户的新增,删除,更新,查找操作

package com.test.service.impl;

import java.util.List;

import com.test.bean.User;
import com.test.dao.UserDAO;
import com.test.service.UserService;

public class UserServiceImpl implements UserService {
	private UserDAO userDao;

	public UserDAO getUserDao() {
		return userDao;
	}

	public void setUserDao(UserDAO userDao) {
		this.userDao = userDao;
	}

	public void save(User user) {
		this.userDao.saveUser(user);
	}

	public List<User> findAll() {
		return this.userDao.findAllUsers();
	}

	public void delete(User user) {
		this.userDao.removeUser(user);
	}

	public void update(User user) {
		this.userDao.updateUser(user);
	}

	public User findById(Integer id) {
		return this.userDao.findUserById(id);
	}
}

 

以下是Action类,一共五个:action类中不处理业务逻辑,业务逻辑都放在service类中处理,action主要处理转发。其中UpdatePUserAction用于查找需要被修改的数据。并将其值返回到update.jsp页面

 

ListUserAction.java ,查找所有用户,其值返回到list.jsp

package com.test.action.user;

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.test.service.UserService;

public class ListUserAction extends ActionSupport {
	private UserService userService;

	public UserService getUserService() {
		return userService;
	}

	public void setUserService(UserService userService) {
		this.userService = userService;
	}

	public String execute() throws Exception {
		Map request = (Map) ActionContext.getContext().get("request");
		request.put("list", this.userService.findAll());
		return "success";
	}

}

 

删除用户

package com.test.action.user;

import com.opensymphony.xwork2.ActionSupport;
import com.test.bean.User;
import com.test.service.UserService;

public class RemoveUserAction extends ActionSupport {
	private User user;
	private UserService userService;

	public User getUser() {
		return user;
	}

	public void setUser(User user) {
		this.user = user;
	}

	public UserService getUserService() {
		return userService;
	}

	public void setUserService(UserService userService) {
		this.userService = userService;
	}

	public String execute() throws Exception {
		this.userService.delete(user);
		return "success";
	}
}

 

保存

package com.test.action.user;

import com.opensymphony.xwork2.ActionSupport;
import com.test.bean.User;
import com.test.service.UserService;

public class SaveUserAction extends ActionSupport {
	private User user;
	private UserService userService;

	public User getUser() {
		return user;
	}

	public void setUser(User user) {
		this.user = user;
	}

	public UserService getUserService() {
		return userService;
	}

	public void setUserService(UserService userService) {
		this.userService = userService;
	}
	
	public String execute() throws Exception {
		// 调用 service相关方法,完成实际的业务处理
		this.getUserService().save(user);
		return "success";
	}
}

 

根据传入的ID值返回需要被更新的user信息

package com.test.action.user;

import com.opensymphony.xwork2.ActionSupport;
import com.test.bean.User;
import com.test.service.UserService;

public class UpdatePUserAction extends ActionSupport {
	private User user;
	private UserService userService;
	public User getUser() {
		return user;
	}
	public void setUser(User user) {
		this.user = user;
	}
	public UserService getUserService() {
		return userService;
	}
	public void setUserService(UserService userService) {
		this.userService = userService;
	}
	public String execute() throws Exception {
		this.user = userService.findById(user.getId());
		return "success";
	}
}

 

更新

package com.test.action.user;

import com.opensymphony.xwork2.ActionSupport;
import com.test.bean.User;
import com.test.service.UserService;

public class UpdateUserAction extends ActionSupport {
	private User user;
	private UserService userService;
	public User getUser() {
		return user;
	}
	public void setUser(User user) {
		this.user = user;
	}
	public UserService getUserService() {
		return userService;
	}
	public void setUserService(UserService userService) {
		this.userService = userService;
	}
	public String execute() throws Exception {
		this.userService.update(user);
		return super.execute();
	}
}

 

struts.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
	<package name="ssh2" extends="struts-default">
			<!--下面这个class的值对应的是spring配置文件中的saveUserAction bean-->
			<action name="saveUser" class="saveUserAction">
						<result name="success" type="redirect">listUser.action</result>
			</action>
			<action name="listUser" class="listUserAction">
						<result name="success">/list.jsp</result>
			</action>
			<action name="deleteUser" class="removeUserAction">
						<result name="success" type="redirect">listUser.action</result>
			</action>
			<action name="updatePUser" class="updatePUserAction">
						<result name="success">update.jsp</result>
			</action>
			<action name="updateUser" class="updateUserAction">
						<result name="success"  type="redirect">listUser.action</result>
			</action>
	</package>
</struts>

 

spring配置文件,所有的bean之前的依赖关系都写在里面

<?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"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
	<!-- 配置连接池数据源,destroy-method="close"表示退出时,将所有连接释放 -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
		<property name="driverClassName">
			<value>com.mysql.jdbc.Driver</value>
		</property>
		<property name="url">
			<value>jdbc:mysql://localhost:3306/hibernate</value>
		</property>
		<property name="username">
			<value>root</value>
		</property>
		<property name="password">
			<value>123456</value>
		</property>
	</bean>		
	<!-- session 工厂 -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="dataSource">
			<ref local="dataSource"/>
		</property>
		<property name="mappingResources">
			<list>
				<value>com/test/bean/User.hbm.xml</value>
			</list>
		</property>
		<property name="hibernateProperties">
			<props>
				<prop key="hibernate.dialect">
					org.hibernate.dialect.MySQLDialect
				</prop>
				<prop key="hibernate.show_sql">
					true
				</prop>
			</props>
		</property>
	</bean>
	<!-- spring事务 -->
	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory">
			<ref local="sessionFactory"/>
		</property>
	</bean>
	<bean id="userServiceTarget" class="com.test.service.impl.UserServiceImpl">
		<property name="userDao">
			<ref local="userDao"/>
		</property>
	</bean>
	<bean id="userService" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
		<property name="target">
			<ref local="userServiceTarget"/>
		</property>
		<property name="transactionManager">
			<ref local="transactionManager"/>
		</property>
		<property name="transactionAttributes">
			<props>
				<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
				<prop key="*">PROPAGATION_REQUIRED</prop>
			</props>
		</property>
	</bean>
	<bean id="userDao" class="com.test.dao.impl.UserDAOImpl" scope="singleton">
		<property name="sessionFactory">
			<ref local="sessionFactory"/>
		</property>
	</bean>
	<bean id="saveUserAction" class="com.test.action.user.SaveUserAction" scope="prototype">
		<property name="userService">
			<ref local="userService"/>
		</property>
	</bean>
	<bean id="listUserAction" class="com.test.action.user.ListUserAction" scope="prototype">
		<property name="userService">
			<ref local="userService"/>
		</property>
	</bean>
	<bean id="removeUserAction" class="com.test.action.user.RemoveUserAction" scope="prototype">
		<property name="userService">
			<ref local="userService"/>
		</property>
	</bean>
	<bean id="updatePUserAction" class="com.test.action.user.UpdatePUserAction" scope="prototype">
		<property name="userService">
			<ref local="userService"/>
		</property>
	</bean>
	<bean id="updateUserAction" class="com.test.action.user.UpdateUserAction" scope="prototype">
		<property name="userService">
			<ref local="userService"/>
		</property>
	</bean>
</beans>


 

hibernate配置文件,基本无配置

hibernate.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<!-- Generated by MyEclipse Hibernate Tools.                   -->
<hibernate-configuration>

    <session-factory>
    </session-factory>

</hibernate-configuration>

 

以下是JSP页面

index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
  <head>
  </head>
  <body>
    <h1><font color="red">operation list</font></h1>
    <s:a href ="save.jsp">save user</s:a><br><br><br>
    <s:a href="listUser.action">List Users</s:a>
  </body>
</html>

 

显示所有用户界面

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
  <head>
  	<SCRIPT type="text/javascript">
  		function del(){
  			if(confirm("are you sure?")){
  				return true;
  			}
  			return false;
  		}
  	</SCRIPT>
  </head>
  <body>
    <h1><font color="red">list user</font></h1>
    <table border="1" width="80% align="center">
    	<tr>
    		<td>
    			序号
    		</td>
    		<td>
    			姓
    		</td>
    		<td>
    			名
    		</td>
    		<td>
    			年龄
    		</td>
    		<td>
    			删除
    		</td>
    		<td>
    			更新
    		</td>
    	</tr>
    	<s:iterator value="#request.list" id="us">
    		<tr>
    			<td>
    				<s:property value="#us.id"/>
    			</td>
    			<td>
    				<s:property value="#us.firstname"/>
    			</td>
    			<td>
    				<s:property value="#us.lastname"/>
    			</td>
    			<td>
    				<s:property value="#us.age"/>
    			</td>
    			<td>
    				<!-- 通过updatePUser.action从数据库中取出此ID对应的数据,并传到update.jsp上 -->
    				<s:a href="updatePUser.action?user.id=%{#us.id}">update</s:a>
    			</td>
    			<td>
    				<s:a href="deleteUser.action?user.id=%{#us.id}" οnclick="return del();"> delete</s:a>
    			</td>
    		</tr>
    	</s:iterator>
    </table>
  </body>
</html>

 

保存页面

<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
  <head>
  </head>
  <body>
    <h1><font color="red">save user</font></h1>
    <s:form action="saveUser">
    	<s:textfield name="user.firstname" label="first name"></s:textfield>
    	<s:textfield name="user.lastname" label="last name"></s:textfield>
    	<s:textfield name="user.age" label="age"></s:textfield>
    	<s:submit value="submit"></s:submit>
    </s:form>
  </body>
</html>

 

更新页面

<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
  <head>
  </head>
  <body>
    <h1><font color="red">update user</font></h1>
    <s:form action="updateUser">
    <table>
    	<tr>
    		<td>
    			<s:hidden name="user.id" value="%{user.id}"></s:hidden>
    		</td>
    	</tr>
    	<tr>
    		<td>
    			<s:textfield name="user.firstname" value="%{user.firstname}" label="firstname"></s:textfield>
    		</td>
    	</tr>
    	<tr>
    		<td>
    			<s:textfield name="user.lastname" value="%{user.lastname}" label="lastname"></s:textfield>
    		</td>
    	</tr>
    	<tr>
    		<td>
    			<s:textfield name="user.age" value="%{user.age}" label="age"></s:textfield>
    		</td>
    	</tr>
    	<tr>
    		<td>
    			<s:submit value="submit"></s:submit>
    		</td>
    	</tr>
    </table>
    </s:form>
  </body>
</html>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值