SpringMVC JSP解决表单重复提交问题
web应用在用户表单操作的时候由于连续点击或者界面提交完刷新等情况,会出现重复提交的问题。下面给出其中一种解决方案:利用session和表单的token值做对比,如果不相等则表示重复提交。
1.自定义标签
<?xml version="1.0" encoding="UTF-8"?> <taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd" version="2.0"> <description>viway view tag lib</description> <tlib-version>3.0</tlib-version> <short-name>viway</short-name> <uri>http://www.viway.com/tag/view</uri> <tag> <name>token</name> <tag-class>com.viway.project.jsp.tag.TokenTag</tag-class> <body-content>empty</body-content> <attribute> <name>token</name> <required>false</required> </attribute> </tag> </taglib>
2.token class
public class TokenTag extends RequestContextAwareTag { private static final long serialVersionUID = 4140002821890713194L; private String token = null; public String getToken() { return token; } public void setToken(String token) { this.token = token; } @Override protected int doStartTagInternal() throws Exception { String token = UUIDGenerator.getUUID(); pageContext.getSession().setAttribute("token", token); setToken(token); StringBuffer sb = new StringBuffer(); sb.append("<input"); sb.append(" type=\"" + "hidden" + "\""); sb.append(" name=\"" + "token" + "\""); sb.append(" value=\"" + token + "\""); sb.append(" />"); pageContext.getOut().println(sb.toString()); return SKIP_BODY; } @Override public int doEndTag() throws JspException { return EVAL_PAGE; } }
3.在form表单里增加tag
<form name="mvcForm" action="action.do" method="post"> <vy:token/> username: <input name="username" type="text" /> password: <input name="password" type="password" /> <input type="submit" value="提交" /> </form>
4.在controller层的post方法里增加校验
@RequestMapping(value = "/doregister", method = RequestMethod.POST) public ModelAndView doRegister( @ModelAttribute("registerBean") @Valid RegisterBean registerBean, BindingResult result, HttpServletRequest request) { ModelAndView mav = new ModelAndView(); if (isDupSubmit(request)) { logger.warn("重复提交表单"); mav.setViewName("cust/register"); return mav; }else{ //todo } ]
//比较token是否一致的方法
public boolean isDupSubmit(HttpServletRequest request) { String serverToken = (String) request.getSession(false).getAttribute( "token"); if (serverToken == null) { return true; } String clinetToken = request.getParameter("token"); System.out.println("serverToken:" + serverToken + " clinetToken:" + "" + clinetToken); if (clinetToken == null) { return true; } if (!serverToken.equals(clinetToken)) { return true; } return false; }