Rumah  >  Artikel  >  Java  >  Bagaimanakah Java mengehadkan permintaan berulang pada bahagian hadapan?

Bagaimanakah Java mengehadkan permintaan berulang pada bahagian hadapan?

WBOY
WBOYke hadapan
2023-05-14 22:58:041397semak imbas

Latar belakang dan tujuan

Halaman bahagian hadapan tersekat, dan pengguna berulang kali mengklik butang operasi, menyebabkan antara muka bahagian belakang diserahkan beberapa kali dalam tempoh masa yang singkat

Pelaksanaan langkah

Tetapkan aspek, Tambah anotasi supaya antara muka tidak boleh dipanggil berulang kali dalam masa yang ditetapkan

Tetapkan antara muka NoRepeatSubmit

import java.lang.annotation.*;
/**
 * xzj_2022_8_2
 * 重复请求限制切面
 */
@Target(ElementType.METHOD) //注解放置的目标位置,METHOD是可注解在方法级别上
@Retention(RetentionPolicy.RUNTIME) //注解在哪个阶段执行
@Documented //生成文档
public @interface NoRepeatSubmit {
    String name() default "name:";
}

laksanakan kelas

import java.lang.annotation.*;
/**
 * xzj_2022_8_2
 * 重复请求限制切面
 */
@Target(ElementType.METHOD) //注解放置的目标位置,METHOD是可注解在方法级别上
@Retention(RetentionPolicy.RUNTIME) //注解在哪个阶段执行
@Documented //生成文档
public @interface NoRepeatSubmit {
    String name() default "name:";
}

Gunakan

    @GetMapping(value = "/test")
    @NoRepeatSubmit
    public void test() {
        System.out.println("test");
        }

Tambahan: Mari kita lihat bagaimana java menghalang penyerahan berulang di bahagian hadapan

JAVA menggunakan kunci tempatan tersuai untuk menyelesaikan masalah berulang penyerahan

1. Perkenalkan pakej balang

<dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>31.1-jre</version>
        </dependency>

2. Sesuaikan kunci setempat

package com.hzt.listener;
import java.lang.annotation.*;
/**
 * 自定义-控制重复提交锁
 */
@Target(ElementType.METHOD)     //作用于方法
@Retention(RetentionPolicy.RUNTIME)     //运行时有效
@Documented
@Inherited
public @interface LocalLock {

    String key() default "";
}

3 Sesuaikan aspek anotasi (pelaksanaan pemintas aop)

rreee

4. . Tentukan antara muka pengawal

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;
    }

Hasil panggilan pertama:

Bagaimanakah Java mengehadkan permintaan berulang pada bahagian hadapan?

Hasil panggilan kedua:

Bagaimanakah Java mengehadkan permintaan berulang pada bahagian hadapan?

Atas ialah kandungan terperinci Bagaimanakah Java mengehadkan permintaan berulang pada bahagian hadapan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam