分享

不用struts2的token机制,手动防止表单数据重复提交

 CevenCheng 2011-07-27
struts2的拦截器实现了防止表单重复提交的功能,即token拦截器,在表单提交页面写上<s:token/>,在struts.xml配置文件中相应的action上配置拦截器
此拦截器只能用在有form的提交请求上。如果是通过url链接请求action,就只能手动控制了。请参考“struts2中采用url链接的action请求如何防止重复提交”

// 配置如下
<action name="cbApplySubmit" class="CBApplyAction"
            method
="cbApplyFromSubmit">
<interceptor-ref name="tokenStack" />
<result name="input" type="ivTiles">
                
<param name="attMap">
                    #
{'main':'/assets/businessChange/addChangeBusiness.jsp'}
                
</param>
            
</result>
<result type="redirect-action" name="invalid.token">
<param name="actionName">queryCB</param>
<param name="namespace">/assets/businessChange</param>
</result>

// 页面如下,注意要加在form里面
<s:form method="POST" action="cbApplySubmit" name="anewApplyForm" namespace="/assets/businessChange">
<s:token />
//.//
</s:form>


要是不使用struts2的拦截器,如何防止表单重复提交呢?在struts2里面实现比较简单

1.在跳转到表单填写页面的action里面往session放一个值
public String execute() throws Exception {
// 向session中放置一个值
        ActionContext actionContext = ActionContext.getContext();
        Map session 
= actionContext.getSession();
        session.put(
"session_value", Math.random() + "");

        
return SUCCESS;
    }


2.在表单填写页面加上接收session值的隐藏域,sub是定义在action里面的一个属性,提供get set方法即可

<input type="hidden" name="sub" value="${session_value}"/>

3.在action提交的方法中判断页面提交过来的sub是否不为空,并且等于从session中取出的session_value的值
如果满足,先移除session里的那个值,再执行提交表单操作;如果不满足,就是重复提交,不会提交表单

public String cbApplyFromSubmit() throws Exception {
// 将页面hidden提交的值和session中的值比较
        ActionContext actionContext = ActionContext.getContext();
        Map session 
= actionContext.getSession();
        String obj 
= (String) session.get("session_value");
        
if (sub != null && sub.equals(obj)) {
            session.remove(
"session_value");
                        
// 保存数据
            chBusiness.saveCBApplyForm(changeApplyFormBO);
            
return SUCCESS;
        } 
else {
            
return "invalid";
        }
    }

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多