`

转载-实现struts的令牌功能

阅读更多

实现原理:一致性。jsp生成表单时,在表单中插入一个隐藏<input>字段,该字段就是保存在页面端的token字符串,同时把该字符串存入session中。等到用户提交表单时,会一并提交该隐藏的token字符串。在服务器端,查看下是否在session中含有与该token字符串相等的字符串。如果有,那么表明是第一次提交该表单,然后删除存放于session端的token字符串,再做正常业务逻辑流程;如果没有,那么表示该表单被重复提交,做非正常流程处理,可以警告提示也可以什么也不做。

首先是Token主类

package com.paizuo.framework.util;

import java.util.ArrayList;

import javax.servlet.http.HttpSession;

public class Token {

    
private static final String TOKEN_LIST_NAME = "tokenList";

    
public static final String TOKEN_STRING_NAME = "token";

    
private static ArrayList getTokenList(HttpSession session) {
       Object obj 
= session.getAttribute(TOKEN_LIST_NAME);
       
if (obj != null{
          
return (ArrayList) obj;
       }
 else {
          ArrayList tokenList 
= new ArrayList();
          session.setAttribute(TOKEN_LIST_NAME, tokenList);
          
return tokenList;
       }

    }


    
private static void saveTokenString(String tokenStr, HttpSession session) {
       ArrayList tokenList 
= getTokenList(session);
       tokenList.add(tokenStr);
       session.setAttribute(TOKEN_LIST_NAME, tokenList);
    }

   
    
private static String generateTokenString(){
       
return new Long(System.currentTimeMillis()).toString();
    }


    

    
public static String getTokenString(HttpSession session) {
       String tokenStr 
= generateTokenString();
       saveTokenString(tokenStr, session);
       
return tokenStr;
    }


    

    
public static boolean isTokenStringValid(String tokenStr, HttpSession session) {
       
boolean valid = false;
       
if(session != null){
          ArrayList tokenList 
= getTokenList(session);
          
if (tokenList.contains(tokenStr)) {
             valid 
= true;
             tokenList.remove(tokenStr);
          }

       }

       
return valid;
    }

}

在jsp页面端。

首先import该类:

<%@ page import="com.paizuo.framework.util.Token" %>

表单包含隐藏的token字符串:

<input type="hidden" name="<%=Token.TOKEN_STRING_NAME %>" value="<%=Token.getTokenString(session) %>">

在Server端action中进行检验。

 

if(Token.isTokenStringValid(request.getParameter(Token.TOKEN_STRING_NAME), request.getSession())){
//进行正常业务流程
}

else{
//进行防重复提交处理流程
}

 

 小记:原来以为通过

 value="<%=Token.getTokenString(session) %>"这种jsp写法重复提交时request会重新读一下数据,那样就实现不了这个token的功能了,但是实验以后发现只要没有重回页面,request保存的值跟上一次提交的值完全相同(当然前提是不去改session里值,那些setSttribute之类的做法都无效)

 

分享到:
评论

相关推荐

    spring-webmvc-struts.jar

    spring-webmvc-struts.jar对Struts和Spring整合时需要用到的包

    MYECLIPS--STRUtS教程--PDF

    在基础配置完成后,教程将深入讲解Struts的核心组件,如Action、ActionForm、DispatcherServlet(即Struts的前端控制器)以及配置文件struts-config.xml。Action是处理用户请求的核心类,ActionForm用于封装表单数据...

    仓库管理系统部分代码--struts实现

    而各功能模块的实现,既展示了Struts的核心特性和最佳实践,也反映出软件工程课程设计中对实际问题的解决思路。对于学习和理解Java Web开发,特别是Struts框架的使用,这是一个非常有价值的实践案例。

    J2EE电子商务系统开发从入门到精通--基于Struts和Hibernate技术实现

    - Struts-config.xml文件用于配置Struts框架,包括Action、FormBean等。 **2.7 Struts标签库** - **2.7.1 Bean标签库** - Bean标签库提供了对Bean的操作支持。 - **2.7.2 HTML标签库** - HTML标签库提供了生成...

    跟我学Java_Web--Struts2技术详解

    - Struts2提供了强大的校验功能,可以轻松实现数据验证,提高应用的安全性和用户体验。 **2. 拦截器**: - 拦截器是Struts2的核心组件之一,可以用来处理请求前后的各种操作,如日志记录、事务管理等。 **3. 国际化...

    Struts令牌的使用

    关于讲解struts令牌详细介绍 解决页面重复提交的好方式

    Struts2漏洞检查工具2019版 V2.3.exe

    Struts2漏洞检查工具2019版 警告: 本工具为漏洞自查工具,请勿非法攻击他人网站! ==漏洞编号==============影响版本=========================官方公告==========================================影响范围====...

    Java框架---Struts2 jar包

    1. **核心库**:struts2-core.jar包含框架的核心功能,如Action、Result、Interceptor等,这些都是构建Struts2应用的基础。 2. **插件**:如struts2-convention-plugin.jar、struts2-dojo-plugin.jar等,提供自动化...

    struts-ajax-json-struts包

    Struts-AJAX-JSON-Struts 包是基于经典的Struts框架,为了实现AJAX(异步JavaScript和XML)和JSON(JavaScript Object Notation)交互功能而设计的一组库和资源集合。这个包通常包含了Struts框架的核心组件,以及...

    《轻量级J2EE企业应用实战--Struts+Spring+Hibernate整合开发》源码

    《轻量级J2EE企业应用实战--Struts+Spring+Hibernate整合开发》图书配套源码part1

    struts令牌token实例

    Struts2是一个强大的MVC(Model-View-Controller)框架,广泛应用于Java Web开发中。在Struts2中,为了防止恶意的重复提交或者意外的多次点击,...学习和理解这个实例,将有助于你更好地理解和应用Struts2的令牌功能。

    李兴华\struts\45-使用Struts _ DAO _ Hibernate完成分页

    标题 "李兴华\struts\45-使用Struts _ DAO _ Hibernate完成分页" 暗示了这是一个关于使用Struts、DAO(数据访问对象)模式和Hibernate ORM框架来实现Web应用中的分页功能的教程。描述与标签与标题相同,进一步确认了...

    jsp-基于struts2的银行储蓄系统的实现 源代码

    jsp-基于struts2的银行储蓄系统的实现 源代码 在myeclipse中导入即可 论文在这http://download.csdn.net/detail/caonuoqi/6528379 自己原创积分设置有点多见谅。

    2009MLDN魔乐科技Struts课堂05-Struts_Struts国际化处理

    2009 MLDN魔乐科技 Struts课堂实战视频教程 全6讲 01-Struts_简介与登陆范例 02-Struts_工作原理与核心配置 03-Struts_对于输入参数的...04-Struts_Bean标签功能 05-Struts_Struts国际化处理 非常经典,适合初学者!

    2009MLDN魔乐科技Struts课堂04-Struts_Bean标签功能_(下)

    2009 MLDN魔乐科技 Struts课堂实战视频教程 全6讲 01-Struts_简介与登陆范例 02-Struts_工作原理与核心配置 03-Struts_对于输入参数的...04-Struts_Bean标签功能 05-Struts_Struts国际化处理 非常经典,适合初学者!

    Struts on Ajax-Retrofitting Struts with Ajax Taglibs

    Ajax Parts是一个用于简化Ajax功能实现的工具包。它包含了一组标签库,这些标签库可以帮助开发者轻松地在Struts应用中加入Ajax功能。当用户触发某个事件(如点击按钮、更改表单字段等)时,Ajax Parts会自动发起Ajax...

    struts1-and-struts2.zip_between

    - **Struts1**:使用struts-config.xml配置文件进行动作映射,比较繁琐且不易维护。 - **Struts2**:使用struts.xml或类似的配置文件,但更倾向于使用注解进行配置,更加简洁直观。 3. **表单验证** - **Struts1...

    struts2-core.jar

    struts2-core-2.0.1.jar, struts2-core-2.0.11.1.jar, struts2-core-2.0.11.2.jar, struts2-core-2.0.11.jar, struts2-core-2.0.12.jar, struts2-core-2.0.14.jar, struts2-core-2.0.5.jar, struts2-core-2.0.6.jar,...

    json-lib-2.1.jar和struts2-json-plugin-2.1.8.1.jar

    - 客户端交互:与前端JavaScript库(如jQuery)配合,实现动态更新页面内容。 3. **jQuery**: - AJAX:jQuery简化了XMLHttpRequest的使用,使得异步数据获取(包括JSON)更加便捷。 - JSON解析:jQuery提供了...

Global site tag (gtag.js) - Google Analytics