当咱们学习Session的时候已经经过Session来编写了一个防止表单重复提交的小程序了,咱们来回顾一下咱们当时是怎么作的:html
咱们之前写表达重复提交就花了这么几个步骤…若是有兴趣的同窗能够看一下之前的实现思路:http://blog.csdn.net/hon_3y/article/details/54799494#t11java
Struts2是简化咱们的开发的,表单重复提交也是一件很是经常使用的功能…Struts2也为咱们实现了…固然啦,也是经过拦截器来实现web
<interceptor name="token" class="org.apache.struts2.interceptor.TokenInterceptor"/>
它的实现原理和咱们之前写的思路几乎一致…它不须要另外写一个组件来生成token值,struts2标签就有这么一个功能…所以是十分方便的sql
为了熟悉一下Struts2,咱们也使用Struts2来编写一下上图的程序…数据库
package zhongfucheng.dao; import org.apache.commons.dbutils.QueryRunner; import org.apache.commons.dbutils.handlers.BeanHandler; import org.apache.commons.dbutils.handlers.BeanListHandler; import zhongfucheng.entity.User; import zhongfucheng.utils.Utils2DB; import java.sql.SQLException; import java.util.List; /** * Created by ozc on 2017/5/3. */ public class UserDao { public void add(User user) { try { String sql = "INSERT INTO user(id,username,cellphone,password,address) VALUES (?,?,?,?,?)"; QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource()); queryRunner.update(sql, new Object[]{user.getId(), user.getUsername(), user.getCellphone(), user.getPassword(),user.getAddress()}); } catch (SQLException e) { new RuntimeException("登录失败了!"); } } public User findUser(String id) { try { String sql = "SELECT * FROM user WHERE id=?"; QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource()); return (User) queryRunner.query(sql, new BeanHandler(User.class), new Object[]{id}); } catch (SQLException e) { new RuntimeException("登录失败了!"); } return null; } public List<User> getAll() { try { String sql = "SELECT * FROM user"; QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource()); return (List<User>) queryRunner.query(sql, new BeanListHandler(User.class)); } catch (SQLException e) { new RuntimeException("登录失败了!"); } return null; } public void updateUser(User user) { try { String sql = "UPDATE user SET username=?,password=?,cellphone=? WHERE id=?"; QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource()); queryRunner.update(sql, new Object[]{user.getUsername(), user.getPassword(), user.getCellphone(), user.getId()}); } catch (SQLException e) { new RuntimeException("登录失败了!"); } } }
package zhongfucheng.service; import zhongfucheng.dao.UserDao; import zhongfucheng.entity.User; import zhongfucheng.utils.WebUtils; import java.util.List; /** * Created by ozc on 2017/5/3. */ public class Service { UserDao userDao = new UserDao(); public void add(User user) { //手动设置id,由于在数据库表我没使用自动增加id user.setId(WebUtils.makeId()); //这是之前的表,规定要address,只能手动设置了 user.setAddress("广州"); userDao.add(user); } public User findUser(String id) { return userDao.findUser(id); } public List<User> getAll() { return userDao.getAll(); } public void updateUser(User user) { userDao.updateUser(user); } }
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@taglib prefix="s" uri="/struts-tags" %> <html> <head> </head> <body> <form action="${pageContext.request.contextPath}/user_register" method="post"> <table border="1"> <tr> <td>用户名:<input type="text" name="username"></td> </tr> <tr> <td> 密码:<input type="password" name="password"></td> </tr> <tr> <td>电话:<input type="text" name="cellphone"></td> </tr> <tr> <td><input type="submit" value="提交"></td> </tr> </table> </form> </body> </html>
//这里必定要实例化 User user = new User(); public User getUser() { return user; } public void setUser(User user) { this.user = user; } @Override public User getModel() { return user; } /*******调用service********/ Service service = new Service(); public String register() throws Exception { service.add(user); //注册成功,就跳转到list()方法,list方法就跳转到查看全部用户页面了! return list(); }
<%-- Created by IntelliJ IDEA. User: ozc Date: 2017/5/2 Time: 18:24 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> <%@ taglib prefix="s" uri="/struts-tags" %> <html> <head> <title>列出下载页面</title> </head> <body> <table border="1" align="center"> <tr> <td>用户id</td> <td>用户姓名</td> <td>用户密码</td> <td>用户电话</td> <td>操做</td> </tr> <s:if test="#request.users!=null"> <c:forEach items="${users}" var="user"> <tr> <td>${user.id}</td> <td>${user.username}</td> <td>${user.password}</td> <td>${user.cellphone}</td> <td><a href="${pageContext.request.contextPath}/user_updatePage?id=${user.id}">修改</a></td> </tr> </c:forEach> </s:if> </table> </body> </html>
public String updatePage() throws Exception { //获得用户带过来的id,根据id查找对象 User user222 = service.findUser(user.getId()); ActionContext.getContext().getValueStack().push(user222); return "updatePage"; }
<form action="${pageContext.request.contextPath}/user_update"> <table border="1"> <tr> <td>用户名<s:textfield name="username"/></td> </tr> <tr> <td>密码 <s:textfield name="password" /></td> </tr> <tr> <td>电话<s:textfield name="cellphone"/></td> </tr> <s:hidden name="id"/> <tr> <td><input type="submit" value="修改"></td> </tr> </table> </form>
上面咱们已经完成了大部分的功能了,但当咱们若是提交以后,再刷新页面,那么表单的数据就会重复提交…咱们使用Struts2咱们提供的防止表单重复提交的功能把!apache
<table border="1"> <s:token></s:token> <tr> <td>用户名:<input type="text" name="username"></td> </tr> <tr> <td> 密码:<input type="password" name="password"></td> </tr> <tr> <td>电话:<input type="text" name="cellphone"></td> </tr> <tr> <td><input type="submit" value="提交"></td> </tr> </table>
token拦截器默认是不会启动的,也就是说:须要咱们手动配置…小程序
当咱们配置拦截器的时候,Struts2默认的拦截器是不会执行的,因此要把Struts2默认的拦截器也写上markdown
<?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> <constant name="struts.ui.theme" value="simple"/> <package name="xxx" extends="struts-default"> <action name="user_*" class="zhongfucheng.action.UserAction" method="{1}"> <interceptor-ref name="defaultStack"/> <interceptor-ref name="token"> <!-- 要拦截的方法! --> <param name="includeMethods">register</param> </interceptor-ref> <!--若是是list,那么就跳转到list的JSP页面--> <result name="list"> /list.jsp</result> <!--请求跳转到修改页面--> <result name="updatePage">/update.jsp</result> <!--若是校验成功,跳转到login.jsp页面回显--> <result name="success">/login.jsp</result> <result name="redirectList" type="redirect">/user_list</result> </action> </package> <include file="config.xml"/> </struts>