struts2 自带的 token防止表单重复提交拦截器
在struts2中,我们可以利用struts2自带的token拦截器轻松实现防止表单重复提交功能!
1. 在相应的action配置中增加:
<interceptor-ref name="token"></interceptor-ref>
<result name="invalid.token">/error.jsp</result>
2. 增加error.jsp文件,代码如下:
<h1>禁止重复提交</h1>
3. 在所提交的表单上增加:<s:token></s:token>标记。
<form action="firstAction">
     <input name="uname" value="zhangsan"><br>
    	    <s:token></s:token>
    	    <input type="submit" value="提交">
      </form>
web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_9" version="2.4" 
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
      <filter>
            <filter-name>struts2</filter-name>
            <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
      </filter>
      <filter-mapping>
            <filter-name>struts2</filter-name>
            <url-pattern>/*</url-pattern>
      </filter-mapping>
</web-app>
struts.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
	  <package name="crm"  namespace="/"  extends="struts-default" >
		    <interceptors>
			      <interceptor name="myInter" class="com.huawei.interceptor.MyInterceptor"  />
    		      <interceptor-stack name="myStack">
    			        <interceptor-ref name="defaultStack" />
    			        <!-- <interceptor-ref name="myInter" /> -->
    		           <interceptor-ref name="token" /> 
    		      </interceptor-stack>
    	    </interceptors>
    	    <default-interceptor-ref name="myStack" />
    	    <!-- 全局result -->
    	    <global-results>
    		      <result  name="success">/ok.jsp</result>
    	    </global-results>
	  </package>
      <package name="default" namespace="/"  extends="crm">
      	    <action name="firstAction"  class="com.huawei.s2.action.FirstAction" >
      		        <result name="invalid.token"  >/error.jsp</result>
      	    </action>
      </package>
</struts>
Action:
package com.huawei.s2.action;
public class FirstAction {
	  private String uname;
	  public String execute(){
		    System.out.println(uname+"========FirstAction=======");
		    return "success";
	  }
	  public String getUname() {
		    return uname;
	  }
	  public void setUname(String uname) {
		    this.uname = uname;
	  }
}
interceptor:
package com.huawei.interceptor;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
/**
 * 要么实现  Interceptor 接口   要么  继承类
 * @author Administrator
 *
 */
public class MyInterceptor extends AbstractInterceptor{
  @Override
	  public String intercept(ActionInvocation invocation) throws Exception {
		    System.out.println(invocation.getAction()); 
		    System.out.println(invocation.getInvocationContext());
		    System.out.println(invocation.getProxy().getActionName());
		    System.out.println(invocation.getProxy().getMethod());
		    System.out.println(invocation.getInvocationContext().getParameters());
		    System.out.println("action执行前");
		    invocation.invoke();
		    System.out.println("action执行后");
		    return null;
	  }
}
jsp:
1.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@taglib prefix="s" uri="/struts-tags" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
      <base href="<%=basePath%>">
      <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">    
      <title>This is my JSP page</title>    
	  <meta http-equiv="pragma" content="no-cache">
	  <meta http-equiv="cache-control" content="no-cache">
	  <meta http-equiv="expires" content="0">    
	  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	  <meta http-equiv="description" content="This is my page">	 
  </head>  
  <body>
      <form action="firstAction">
    	    <input name="uname" value="zhangsan"><br>
    	    <s:token></s:token>
    	    <input type="submit" value="提交">
      </form>
  </body>
</html>
ok.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <base href="<%=basePath%>">
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">   
        <title>This is my JSP page</title>   
	    <meta http-equiv="pragma" content="no-cache">
	    <meta http-equiv="cache-control" content="no-cache">
	    <meta http-equiv="expires" content="0">    
	    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	    <meta http-equiv="description" content="This is my page">
    </head> 
    <body>
        <h1>提交成功</h1>    
    </body>
</html>
error.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <base href="<%=basePath%>">
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">   
        <title>This is my JSP page</title>    
	    <meta http-equiv="pragma" content="no-cache">
	    <meta http-equiv="cache-control" content="no-cache">
	    <meta http-equiv="expires" content="0">    
	    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	    <meta http-equiv="description" content="This is my page">
    </head> 
    <body>
        <h1>禁止重复提交</h1>
    </body>
</html>
struts2 自带的 token防止表单重复提交拦截器的更多相关文章
- AOP+Token防止表单重复提交
		表单重复提交: 由于用户误操作,多次点击表单提交按钮 由于网速等原因造成页面卡顿,用户重复刷新提交页面 避免表单重复提交的方式: 1.页面上的按钮做防重复点击操作 2.在数据库中可以做唯一约束 3.利 ... 
- PHP简单利用token防止表单重复提交
		<?php /* * PHP简单利用token防止表单重复提交 * 此处理方法纯粹是为了给初学者参考 */ session_start(); function set_token() { $_S ... 
- PHP生成token防止表单重复提交
		.提交按钮置disabled 当用户提交后,立即把按钮置为不可用状态.这种用js来实现. 提交前代码如下: $() { $exec="insert into student (user_ ... 
- PHP简单利用token防止表单重复提交(转)
		<?php/* * PHP简单利用token防止表单重复提交 */function set_token() { $_SESSION['token'] = md5(microtime(true)) ... 
- php通过token验证表单重复提交
		PHP防止重复提交表单 2016-11-08 轻松学PHP 我们提交表单的时候,不能忽视的一个限制是防止用户重复提交表单,因为有可能用户连续点击了提交按钮或者是攻击者恶意提交数据,那么我们在提交数据后 ... 
- PHP使用token防止表单重复提交的方法
		本文实例讲述了PHP使用token防止表单重复提交的方法.分享给大家供大家参考,具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 2 ... 
- Struts2笔记——利用token防止表单重复提交
		在一些项目中经常会让用户提交表单,当用户点击按钮提交后,如果再次浏览器刷新,这就会造成表单重复提交,若是提交的内容上传至服务器并请求数据库保存,重复提交的表单可能会导致错误,然后跳转到错误界面,这是一 ... 
- Struts2第十三篇【防止表单重复提交】
		回顾防止表单重复提交 当我们学习Session的时候已经通过Session来编写了一个防止表单重复提交的小程序了,我们来回顾一下我们当时是怎么做的: 在Servlet上生成独一无二的token,保存在 ... 
- token防止表单重复提交
		出现表单重复提交的三种情况: 一.服务器响应缓慢,用户多次点击提交按钮. 二.提交成功后刷新页面. 三.提交成功后返回表单页面再次点击提交. package com.jalja.token; impo ... 
随机推荐
- 关于Hibernate Could not obtain transaction-synchronized Session for current thread
			转载自 http://blog.csdn.net/flyjiangs/article/details/51537381 最近几年一直再搞android,最近闲下来了,顺便玩一下web. 整了个最新版本 ... 
- Python网络爬虫-requests模块(II)
			有些时候,我们在使用爬虫程序去爬取一些用户相关信息的数据(爬取张三“人人网”个人主页数据)时,如果使用之前requests模块常规操作时,往往达不到我们想要的目的,例如: #!/usr/bin/env ... 
- POJ 2706 Painter
			Painter Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3157 Accepted: 1962 Descripti ... 
- php实现AES/CBC/PKCS5Padding加密解密(又叫:对称加密)
			今天在做一个和java程序接口的架接,java那边需要我这边(PHP)对传过去的值进行AES对称加密,接口返回的结果也是加密过的(就要用到解密),然后试了很多办法,也一一对应了AES的key密钥值,偏 ... 
- echo off
			就是说关闭回显 @echo off并不是DOS程序中的,而是DOS批处理中的.当年的DOS,所有操作都用键盘命令来完成,当你每次都要输入相同的命令时,可以把这么多命令存为一个批处理,从此以后,只要运行 ... 
- linux read 系统调用剖析
			https://www.ibm.com/developerworks/cn/linux/l-cn-read/ MT注:原文图1与Understanding the Linux Kernel, 3rd ... 
- 洛谷P1415 拆分数列
			题目背景 [为了响应党中央勤节俭.反铺张的精神,题目背景描述故事部分略去^-^] 题目描述 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输出使得最后一个数最小的同时 ... 
- MS SQL Server 定时任务实现自动备份
			SQL Server Express 版本是没有SQL 代理服务的,从而导致不能使用SQL Server的定时自动备份功能.真心感觉这就是一个坑,虽然Express是学习的版本,但是精简的也太多了.另 ... 
- C# DbHelperSQL 类,从东软生成器提取而来
			DBHelerSQL,可以结合东软生成器写简单三层结构,也可以自己去调用执行相关SQL语句 直接上代码: using System; using System.Collections; using S ... 
- filzilla
			之前找了一套支援 SFTP (FTP over SSH) 的 FTP Server 就是為了解決 Port 不夠用的問題,直到最近才發現我們常用的 FileZilla Server 原來就有支援 FT ... 
