• Struts2之防止表单重复提交


    时间:2017-1-14 22:29

    ——普通方法

    如何解决表单重复提交?
        在JSP页面中生成一个令牌(随机字符串),将其存储到session中,并在表单中携带,提交给服务器。
        在服务器端获取请求参数时,同时获取令牌,将她与session中存储的token进行比较,如果没问题,则执行操作。
        获取令牌后马上将session中的令牌删除。

    示例代码:

        JSP页面:
            <body>

            <%
                String token = UUID.randomUUID().toString();
                session.setAttribute("token", token);
            %>
     
            <form action="${pageContext.request.contextPath}/RegistServlet" method="post">
                <input type="hidden" name="token" value="<%=token %>" />
                username:<input type="text" name="username" /><br />
                <input type="submit" value="注册" />
            </form>
    </body>


        Servlet:
            public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

     
                response.setContentType("text/html;charset=utf-8");
     
                String token = (String) request.getSession().getAttribute("token");
                String _token = request.getParameter("token");
     
                request.getSession().removeAttribute("token");
     
                if(_token.equals(token)){
                    System.out.println("注册成功:" + request.getParameter("username"));
                } else {
                    response.getWriter().print("禁止重复提交表单");
                }
            }


    ——Struts2解决表单重复提交

    在Struts2中解决表单重复提交的问题,可以使用Struts2定义的一个Interceptor:token

    token拦截器没有在默认的18个拦截器(defaultStack)中。

    步骤
        1、在页面中使用token tag标签
            >   会在页面上生成一个令牌,并存在于表单中。
        2、在<action>标签中引入<token>拦截器。
            >   <interceptor-ref name="token"/>
        3、配置invalid.token视图
            >   <result name="invalid.token">/index.jsp</result>
        4、在页面中使用<s:actionerror />标签显示错误信息。

    JSP页面示例代码:

        <form action="${pageContext.request.contextPath}/regist" method="post">
            <s:token/>
            username:<input type="text" name="username" /><br />
            <input type="submit" value="注册" />

        </form> 

  • 相关阅读:
    CDN 机制
    canvas绘制旋转图形
    前端资源网站
    css中的em用法
    响应式网页设计【转载】
    闭包与非闭包
    跨域文档之间的访问
    ajax跨域之---服务器端代理实现
    jsonp跨域实现
    freemarker 命名空间
  • 原文地址:https://www.cnblogs.com/wwwwyc/p/6375440.html
Copyright © 2020-2023  润新知