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

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";
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值