自定义拦截器解决Struts2重复提交问题

版权申诉
0 下载量 194 浏览量 更新于2024-08-31 收藏 14KB PDF 举报
在Struts2框架中,由于性能问题,项目团队选择不使用内置的标签来防止重复提交,但为了实现这个功能,他们选择自定义拦截器来处理这个问题。本文档详细介绍了如何创建一个名为`TokenAtionInterceptor`的拦截器,以及一个辅助工具类`RandomGUIDUtil`。 首先,创建拦截器类`TokenAtionInterceptor`,它继承了`AbstractInterceptor`基类。该拦截器的主要任务是在每次请求到达时检查是否已经存在一个令牌(即重复提交)。具体步骤如下: 1. **拦截器类实现**: - 在`intercept`方法中,首先获取当前会话(session)和请求(HttpServletRequest)。 - 使用`RandomGUIDUtil`生成一个新的全局唯一标识符(GUID),作为令牌。 - 检查会话中是否存在令牌(`request_token`),如果存在且与表单提交的令牌`token`不同,说明有重复提交,这时重置令牌并返回错误提示"invalidToken"。 - 如果没有重复提交,将新生成的令牌存入会话和请求属性,并继续执行后续的Action逻辑,由`invocation.invoke()`调用。 2. **辅助工具类`RandomGUIDUtil`**: - 这是一个简单的工具类,用于生成随机的全局唯一标识符(GUID)。 - 提供了一个静态方法`newGuid`,通过获取当前类名的`Logger`对象,可以方便地记录日志操作,以确保生成过程的可靠性。 总结起来,自定义拦截器`TokenAtionInterceptor`通过比较会话中的令牌和提交的令牌,实现了防止重复提交的功能。它利用了Struts2框架的拦截机制,在用户尝试提交表单时,确保同一请求不会被重复处理。同时,`RandomGUIDUtil`作为辅助工具,简化了生成和管理唯一令牌的过程。这种设计有助于提高项目的可维护性和扩展性。