天天看點

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

推薦連結:

    總結——》【Java】

    總結——》【Mysql】

    總結——》【Spring】

    總結——》【SpringBoot】

SpringBoot——》限制請求的通路次數

  • 一、資料庫
  • 二、項目
    • 1、pom.xml:引入核心依賴
    • 2、application.yml:配置資料源
    • 3、RequestLimit.java:定義注解
    • 4、RequestLimitAspect.java:定義AOP切面
    • 5、RequestLimitException.java:定義注解異常
    • 6、Application.java:使用@EnableAspectJAutoProxy注解
    • 7、UserController.java:使用@RequestLimit注解
  • 三、啟動
  • 四、測試
    • 1、正常傳回結果
    • 2、抛出異常資訊

一、資料庫

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試
/*
    Schema:test
    Info:測試資料庫
    Date:2022/09/07 13:49:38
*/
-- 1、建立資料庫
CREATE
DATABASE `test` CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';

-- 2、建立表
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`
(
    `id`   bigint(11) NOT NULL AUTO_INCREMENT,
    `name` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
    PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

-- 3、插入資料
INSERT INTO `user`
VALUES (1, '趙');
INSERT INTO `user`
VALUES (2, '錢');
INSERT INTO `user`
VALUES (3, '孫');
INSERT INTO `user`
VALUES (4, '李');
           

二、項目

參考代碼: 【gitee】https://gitee.com/xiaoxianwansui/springboot-request-limit.git
SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

1、pom.xml:引入核心依賴

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.1</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.9</version>
        </dependency>
        <!--測試架構 - start -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!--AspectJ支援-->
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.4</version>
        </dependency>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjrt</artifactId>
            <version>1.9.4</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
           

2、application.yml:配置資料源

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

3、RequestLimit.java:定義注解

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

4、RequestLimitAspect.java:定義AOP切面

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

5、RequestLimitException.java:定義注解異常

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

6、Application.java:使用@EnableAspectJAutoProxy注解

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

7、UserController.java:使用@RequestLimit注解

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

三、啟動

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

四、測試

1、正常傳回結果

http://127.0.0.1:8888/user/list

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試

2、抛出異常資訊

http://127.0.0.1:8888/user/list

SpringBoot——》限制請求的通路次數一、資料庫二、項目三、啟動四、測試