您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Java如何限制前端重復請求”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Java如何限制前端重復請求”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
前端頁面出現卡頓,用戶反復點擊操作按鈕,導致后臺接口短時間內多次提交
設置切面,增加注解,導致在規定時間內該接口不可重復調用
設置一個接口 NoRepeatSubmit
import java.lang.annotation.*; /** * xzj_2022_8_2 * 重復請求限制切面 */ @Target(ElementType.METHOD) //注解放置的目標位置,METHOD是可注解在方法級別上 @Retention(RetentionPolicy.RUNTIME) //注解在哪個階段執行 @Documented //生成文檔 public @interface NoRepeatSubmit { String name() default "name:"; }
實現類
import java.lang.annotation.*; /** * xzj_2022_8_2 * 重復請求限制切面 */ @Target(ElementType.METHOD) //注解放置的目標位置,METHOD是可注解在方法級別上 @Retention(RetentionPolicy.RUNTIME) //注解在哪個階段執行 @Documented //生成文檔 public @interface NoRepeatSubmit { String name() default "name:"; }
使用
@GetMapping(value = "/test") @NoRepeatSubmit public void test() { System.out.println("test"); }
補充:下面看下java防止前端重復提交
JAVA利用自定義本地鎖解決重復提交的問題
1.引入jar包
<dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>31.1-jre</version> </dependency>
2.自定義本地鎖
package com.hzt.listener; import java.lang.annotation.*; /** * 自定義-控制重復提交鎖 */ @Target(ElementType.METHOD) //作用于方法 @Retention(RetentionPolicy.RUNTIME) //運行時有效 @Documented @Inherited public @interface LocalLock { String key() default ""; }
3.自定義注解切面 (aop攔截器實現)
import com.google.common.cache.Cache; import com.google.common.cache.CacheBuilder; import org.apache.commons.lang3.StringUtils; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Configuration; import java.util.concurrent.TimeUnit; /** * @Desc: 自定義注解攔截器 * @Author: zmk * @Date: 2022/4/2 */ @Aspect @Configuration public class LockMethodInterceptor { private final Logger log = LoggerFactory.getLogger(LockMethodInterceptor.class); private static final Cache<String, Object> CACHES = CacheBuilder.newBuilder() //最大緩存數 .maximumSize(1000) //設置過期時間 .expireAfterWrite(3, TimeUnit.SECONDS) .build(); @Around(value = "@annotation(localLock)") public Object interceptor (ProceedingJoinPoint point, LocalLock localLock) { //localLock.key() 這個是獲取controller的key屬性, point.getArgs()獲取key的值 String key = getKey(localLock.key(), point.getArgs()); if (StringUtils.isNotBlank(key)) { if (CACHES.getIfPresent(key) != null) { throw new RuntimeException("請勿重復提交"); } //如果是第一次請求, 將key放入緩存 CACHES.put(key, key); } try { return point.proceed(); } catch (Throwable throwable) { throw new RuntimeException("服務器異常"); } finally { //標記為無效 // CACHES.invalidate(key); } } /** * * key 生成策略 * @param key key表達式 * @param args 參數 * @return 生成的key */ private String getKey(String key, Object[] args) { for (int i = 0; i < args.length; i++) { key = key.replace("arg[" + i + "]", args[i].toString()); } return key; }
4.定義controller接口
@GetMapping("/query") @LocalLock(key = "param:arg[0]") public String query (@RequestParam("abc") String abc) { return "ok"; }
第一次調用結果:
第二次調用結果:
讀到這里,這篇“Java如何限制前端重復請求”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。