1 javascript ,设置一个变量,只允许提交一次。
SynchroToken.java Title: SynchroToken Description: Copyright: Copyright (c) 2004 Company: NetStar ? 4 添加中转页面
2 还是javascript,将提交按钮或者image置为disable ?
3 利用struts的同步令牌机制 ?
利用同步令牌(Token)机制来解决Web应用中重复提交的问题,Struts也给出了一个参考实现。?
基本原理: ?
服务器端在处理到达的请求之前,会将请求中包含的令牌值与保存在当前用户会话中的令牌值进行比较,看是否匹配。在处理完该请求后,且在答复发送给客户端之前,将会产生一个新的令牌,该令牌除传给客户端以外,也会将用户会话中保存的旧的令牌进行替换。这样如果用户回退到刚才的提交页面并再次提交的话,客户端传过来的令牌就和服务器端的令牌不一致,从而有效地防止了重复提交的发生。 ?
if (isTokenValid(request, true)) {?
// your code here?
return mapping.findForward("success");?
} else {?
saveToken(request);?
return mapping.findForward("submitagain");?
} ?
Struts根据用户会话ID和当前系统时间来生成一个唯一(对于每个会话)令牌的,具体实现可以参考TokenProcessor类中的generateToken()方法。 ?
1. //验证事务控制令牌, <html:form> 会自动根据session中标识生成一个隐含input代表令牌,防止两次提交?
2. 在action中: ?
在更新的时候防止按钮重复点击,主要是用Session来做判断
在JSP/Servlet中可以
JSP页面
package com.lims.util;
import org.apache.struts.util.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
import org.apache.struts.action.*;
/**
? *
? *
? *
? *
? * @author Jstar
? * @version 1.0
? * Created in 2004/04/21
? */
public class SynchroToken{
?public final static java.lang.String TOKEN_NAME = "_token";
?public static boolean checkToken (HttpServletRequest request){
?? boolean isEqual = false;
?? HttpSession session = request.getSession ();
?? String formToken = request.getParameter (TOKEN_NAME);
?? String sessionToken = (String)session.getAttribute (TOKEN_NAME);
?? System.out.println ("formToken: " + formToken + " sessionToken: " +
?????????????????????? sessionToken);
?? if (formToken != null && sessionToken == null){
???? session.setAttribute (TOKEN_NAME, formToken);
???? isEqual = true;
?? }
?? return isEqual;
?}
?/**
? * Insert the method's description here.
? * Creation date: (4/19/2004 3:23:25 PM)
? * @return java.lang.String
? * @param request javax.servlet.http.HttpServletRequest
? */
?public static String getToken (HttpServletRequest request){
?? String token = "" + System.currentTimeMillis ();
?? HttpSession session = request.getSession ();
?? if (session != null){
???? session.removeAttribute (TOKEN_NAME);
?? }
?? return token;z
?}
?/**
? * Insert the method's description here.
? * Creation date: (4/19/2004 3:24:10 PM)
? * @return java.lang.String
? */
?final static java.lang.String getTOKEN_NAME (){
?? return TOKEN_NAME;
?}
?public static String message (PageContext pageContext, String key) throws
???? JspException{
?? return RequestUtils.message (pageContext, null, null, key);
?}
}
详细解决方案
JSP(Struts)避免Form重复提交的几种草案
热度:419 发布时间:2012-10-28 09:54:44.0
相关解决方案
- struts HTTP Status 500解决办法
- Struts-config.xml配置action-地图pings元素略计
- Struts-config.xml配置文件《action-地图pings》元素的详解
- 求jquery.form.js+jquery.validate.min.js 用ajax提交表单的代码范例
- 关于<form action >的一个有关问题
- 404,500跳转到登录页面,疏失:The Struts dispatcher cannot be found
- 新手求解,使用struts报错Cannot retrieve definition for form bean studsForm on action /stu,该怎么解决
- jquery form 有关问题
- form 表单交付 <form action="<c:url value='desktop'/>"
- 项目好好的,忽然就Unknown tag (s:form).不知道为什么
- java struts 文件上载
- struts hibernate 测试小例子 不报错 但数据库没反应 求分析项目在小弟我的资源里面
- 求SSM分页 struts +spring+mybatis 给小弟我发个学习学习吧 多谢大神们
- 关于 jsp struts-tag <c:if> 判断有关问题
- ENCTYPE="multipart/form-data"文件下传有关问题
- 生手求解,使用struts报错Cannot retrieve definition for form bean studsForm on action /stu
- struts+spring+mybatis出现错误(java.lang.ClassNotFoundException: Entity)为提示位置
- 求解 struts+spring+mybatis sqlsession为空 debug发现没有执行set方法 检查配置好像没有关问题
- CAPTCHA 模块中 ajax form 导致CAPTCHA session reuse attack detected异常,解决方法
- struts + hibernate 后台页面修改数据后,前台页面显示的内容新旧数据交替出现。请高手帮忙分析上原因
- enctype="multipart/form-data"的页面中,获取普通表单中文值,
- struts+spring+hibernate 开发,在action层调用service层接口,结果替null 注入失败,需高手帮忙
- 有个有关问题,请各位帮忙看看:java.lang.ClassNotFoundException: org.apache.struts.action.Act
- struts.xml资料中的namespace"/"当在/后加东西时没起作用
- 生手求教,dwr+struts+spring 页面跳提示框error
- struts checkbox 页面显示
- Servlet struts is not available要如何解决
- 在jsp页面下导入.xls文件,报错:Posted content type isn't multipart/form-data
- struts+hibernate数据库链接池有关问题
- jsp form 表单 提交 带特殊符号 求高手帮忙解答上多谢!