实现原理:一致性。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中进行检验。
//进行正常业务流程
}
else{
//进行防重复提交处理流程
}
小记:原来以为通过
value="<%=Token.getTokenString(session) %>"这种jsp写法重复提交时request会重新读一下数据,那样就实现不了这个token的功能了,但是实验以后发现只要没有重回页面,request保存的值跟上一次提交的值完全相同(当然前提是不去改session里值,那些setSttribute之类的做法都无效)
相关推荐
spring-webmvc-struts.jar对Struts和Spring整合时需要用到的包
在基础配置完成后,教程将深入讲解Struts的核心组件,如Action、ActionForm、DispatcherServlet(即Struts的前端控制器)以及配置文件struts-config.xml。Action是处理用户请求的核心类,ActionForm用于封装表单数据...
而各功能模块的实现,既展示了Struts的核心特性和最佳实践,也反映出软件工程课程设计中对实际问题的解决思路。对于学习和理解Java Web开发,特别是Struts框架的使用,这是一个非常有价值的实践案例。
- Struts-config.xml文件用于配置Struts框架,包括Action、FormBean等。 **2.7 Struts标签库** - **2.7.1 Bean标签库** - Bean标签库提供了对Bean的操作支持。 - **2.7.2 HTML标签库** - HTML标签库提供了生成...
- Struts2提供了强大的校验功能,可以轻松实现数据验证,提高应用的安全性和用户体验。 **2. 拦截器**: - 拦截器是Struts2的核心组件之一,可以用来处理请求前后的各种操作,如日志记录、事务管理等。 **3. 国际化...
关于讲解struts令牌详细介绍 解决页面重复提交的好方式
Struts2漏洞检查工具2019版 警告: 本工具为漏洞自查工具,请勿非法攻击他人网站! ==漏洞编号==============影响版本=========================官方公告==========================================影响范围====...
1. **核心库**:struts2-core.jar包含框架的核心功能,如Action、Result、Interceptor等,这些都是构建Struts2应用的基础。 2. **插件**:如struts2-convention-plugin.jar、struts2-dojo-plugin.jar等,提供自动化...
Struts-AJAX-JSON-Struts 包是基于经典的Struts框架,为了实现AJAX(异步JavaScript和XML)和JSON(JavaScript Object Notation)交互功能而设计的一组库和资源集合。这个包通常包含了Struts框架的核心组件,以及...
《轻量级J2EE企业应用实战--Struts+Spring+Hibernate整合开发》图书配套源码part1
Struts2是一个强大的MVC(Model-View-Controller)框架,广泛应用于Java Web开发中。在Struts2中,为了防止恶意的重复提交或者意外的多次点击,...学习和理解这个实例,将有助于你更好地理解和应用Struts2的令牌功能。
标题 "李兴华\struts\45-使用Struts _ DAO _ Hibernate完成分页" 暗示了这是一个关于使用Struts、DAO(数据访问对象)模式和Hibernate ORM框架来实现Web应用中的分页功能的教程。描述与标签与标题相同,进一步确认了...
jsp-基于struts2的银行储蓄系统的实现 源代码 在myeclipse中导入即可 论文在这http://download.csdn.net/detail/caonuoqi/6528379 自己原创积分设置有点多见谅。
2009 MLDN魔乐科技 Struts课堂实战视频教程 全6讲 01-Struts_简介与登陆范例 02-Struts_工作原理与核心配置 03-Struts_对于输入参数的...04-Struts_Bean标签功能 05-Struts_Struts国际化处理 非常经典,适合初学者!
2009 MLDN魔乐科技 Struts课堂实战视频教程 全6讲 01-Struts_简介与登陆范例 02-Struts_工作原理与核心配置 03-Struts_对于输入参数的...04-Struts_Bean标签功能 05-Struts_Struts国际化处理 非常经典,适合初学者!
Ajax Parts是一个用于简化Ajax功能实现的工具包。它包含了一组标签库,这些标签库可以帮助开发者轻松地在Struts应用中加入Ajax功能。当用户触发某个事件(如点击按钮、更改表单字段等)时,Ajax Parts会自动发起Ajax...
- **Struts1**:使用struts-config.xml配置文件进行动作映射,比较繁琐且不易维护。 - **Struts2**:使用struts.xml或类似的配置文件,但更倾向于使用注解进行配置,更加简洁直观。 3. **表单验证** - **Struts1...
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,...
- 客户端交互:与前端JavaScript库(如jQuery)配合,实现动态更新页面内容。 3. **jQuery**: - AJAX:jQuery简化了XMLHttpRequest的使用,使得异步数据获取(包括JSON)更加便捷。 - JSON解析:jQuery提供了...