利用Token防止重复提交(Struts框架)

利用Token防止重复提交(Struts框架)

 

如果用户对一个html表单多次提交,web应用应该能够判断用户的重复提交行为,并作出相应的处理。 

 

最常见的是新增一条数据,用户已经提交表单并且服务器端已经完成新增成功。此时用户可能有两个误

 

操作: 

1.用户通过浏览器的后退功能,返回到录入页面,重复提交(此时浏览器提供回退功能基本上是个邪恶

 

行为) 

2.刷新该页面(因为新增成功的提示页面通常是通过请求转发(forward)过来的,所以此操作实际效果通

 

常等同于1) 

 

这样造成的可能结果有: 

1.若程序级别和数据库级别限制了重复记录,会提示类似于“xxx字段已存在,请修改后重新保存”的信

 

息 

2.若没有此限制,服务器端会再插入一条数据,而这通常不是用户想要的 

 

误操作2和可能结果2的结合就达成了与用户意图相背的结果:服务器端不停地在增加重复记录,用户认

 

为自己只不过是刷新该提示信息页面。 

 

通用的解决思路是: 

用户请求录入页面,这个与服务器建立的一次连接过程中,在服务器端①【生成一个session标识,同时

 

返回到客户端一个与此匹配的hidden域】。用户提交了此页面,服务器端首先②【判断此hidden域与

 

session标识是否匹配】,若不匹配,终止保存操作,提示同一表单不能提交两次,同时①【新建一个

 

session标识和hidden域】,返回录入页面;若匹配,执行插入保存操作,同时③【清空(重置reset)

 

session标识】。 

 

Struts正在基于这样的思路在org.apache.struts.action.Action类中提供了内置支持方法: 

java代码: 

 

protected void saveToken(HttpServletRequest request) 配合标签对应于① 

protected boolean isTokenValid(HttpServletRequest request) 对应于② 

protected void resetToken(HttpServletRequest request) 对应于③

 

这样我们在写程序的时候,结合Struts的html标签,只要 

1.在forward到insert.jsp页面前加一个action执行saveToken(request)操作,或干脆在insert.jsp中写 

2.保存前加个判断操作isTokenValid(request) 

3.若isTokenValid(request)返回false,执行saveToken(request)操作,返回错误提示页面;true则执行

 

resetToken(request)操作,然后进行实际的保存操作

 

我的代码

 

 

// 进入创建前的Action

public final class EnterNewProjectPageAction extends Action {

        public ActionForward execute(ActionMapping mapping, ActionForm form,

                        HttpServletRequest request, HttpServletResponse response)

                        throws Exception {        

 

                saveToken(request);

 

                return (mapping.findForward("createproject_jsp"));

        }

}

 

// 创建Action

public final class CreateProjectAction extends Action {

        public ActionForward execute(ActionMapping mapping, ActionForm form,

                        HttpServletRequest request, HttpServletResponse response)

                        throws Exception {        

 

 

                if(isTokenValid(request)){

                        resetToken(request);

 

                        CreateProjectForm createProjectForm=(CreateProjectForm)form;        

                        Project newProject=createProjectForm.getProject();

 

                        newProject.setCreateTime(Util.getCurrTime());

 

                        ProjectService.create(newProject);        

 

                }

                else{

                        saveToken(request);

                        System.out.println("重复提交");

                }                

 

                ProjectUtil.setupPages(0,request);

                return (mapping.findForward("projects_jsp"));

        }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值