java代码防止重复提交
时间: 2023-07-02 17:10:46 浏览: 97
防止重复提交的方法有很多种,其中比较常用的有以下几种:
1. 隐藏表单域:在表单中添加一个隐藏域,每次提交表单时检查该隐藏域的值是否已经被使用过,如果已经被使用过,则说明是重复提交,需要拒绝提交。
2. 重定向:提交表单后,服务器端处理完成后返回一个重定向响应,让浏览器重新向另一个页面发起请求,这样可以防止用户通过“后退”按钮再次提交表单。
3. Token 验证:在表单中添加一个唯一性的 Token,每次提交表单时验证该 Token 是否有效,如果无效,则说明是重复提交,需要拒绝提交。
下面是一个基于 Token 验证的 Java 代码示例:
``` java
public class TokenUtil {
public static final String TOKEN_PREFIX = "TOKEN_";
// 生成 Token
public static String generateToken() {
String token = UUID.randomUUID().toString();
// 将 Token 存入 Session
HttpSession session = request.getSession();
session.setAttribute(TOKEN_PREFIX + token, token);
return token;
}
// 验证 Token
public static boolean isValidToken(HttpServletRequest request) {
String token = request.getParameter("token");
if (token == null) {
return false;
}
HttpSession session = request.getSession();
Object sessionToken = session.getAttribute(TOKEN_PREFIX + token);
if (sessionToken == null || !sessionToken.equals(token)) {
return false;
}
// 验证通过后,从 Session 中移除 Token
session.removeAttribute(TOKEN_PREFIX + token);
return true;
}
}
```
在表单中添加一个隐藏域,用于存放 Token:
```html
<form method="post" action="submit.do">
<input type="hidden" name="token" value="${token}" />
<!-- 其他表单元素 -->
<input type="submit" value="提交" />
</form>
```
在服务器端处理表单提交时,先验证 Token 是否有效:
```java
if (!TokenUtil.isValidToken(request)) {
// Token 验证失败,拒绝提交
return "error";
}
// 处理表单提交
// ...
```
阅读全文