java如何防止接口重复提交,写出方法实例
时间: 2024-03-21 20:14:03 浏览: 72
Java怎样防止重复提交
接口重复提交指的是用户在短时间内多次提交同一个请求,这种情况会增加服务器的负担,甚至会导致数据的错误。
防止接口重复提交的方法有很多种,以下是一种通过 Token 防止重复提交的方法:
1. 在前端页面中添加一个隐藏的 Token 字段,该 Token 字段的值是随机生成的一个字符串,并且只会在首次提交时生成。
2. 当用户提交请求时,服务器首先检查 Token 字段的值是否与之前的值相同,如果相同,则表示该请求是重复提交的,服务器返回错误信息。
3. 如果 Token 字段的值不同,则表示该请求是新的请求,服务器处理该请求,并更新 Token 字段的值。
Java 代码实现:
```java
public class TokenUtil {
private static final String TOKEN_PREFIX = "token:";
private static final int TOKEN_EXPIRE_TIME = 60; // Token 有效期(秒)
public static String generateToken() {
String token = UUID.randomUUID().toString();
RedisUtil.set(TOKEN_PREFIX + token, "1", TOKEN_EXPIRE_TIME);
return token;
}
public static boolean checkToken(String token) {
if (StringUtils.isEmpty(token)) {
return false;
}
String key = TOKEN_PREFIX + token;
String value = RedisUtil.get(key);
if (StringUtils.isEmpty(value)) {
return false;
}
RedisUtil.del(key);
return true;
}
}
```
在接口中使用 Token 防止重复提交:
```java
@RestController
public class UserController {
@PostMapping("/user")
public String addUser(@RequestBody User user, @RequestParam String token) {
if (!TokenUtil.checkToken(token)) {
return "请勿重复提交!";
}
// 处理用户添加请求
// ...
String newToken = TokenUtil.generateToken();
return newToken;
}
}
```
在前端页面中添加 Token 字段:
```html
<form method="POST" action="/user">
<input type="hidden" name="token" value="${token}">
<input type="text" name="username">
<input type="password" name="password">
<button type="submit">提交</button>
</form>
```
以上代码使用 Redis 存储 Token,需要先引入 Redis 相关依赖并进行配置。
阅读全文