SpringBoot Aop实现接口请求次数统计

 更新时间:2024年02月06日 14:44:20   作者:wx59bcc77095d22  
我们通过Spring AOP在每次执行方法前或执行方法后进行切面的处理,进而统计方法访问的次数等功能,本文主要介绍了SpringBoot Aop实现接口请求次数统计

一、前言

我们通过Spring AOP在每次执行方法前或执行方法后进行切面的处理,进而统计方法访问的次数等功能,可以持久化到数据库或者后面进行接口并发的处理。

二、添加依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.31</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

三、项目配置

我们主要添加数据库相关的配置。

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/aop_db?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowPublicKeyRetrieval=true
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true

四、创建自定义计数注解

package com.example.aopdemo.annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 访问次数注解
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface VisitCount {

}

五、创建实体类和持久层

package com.example.aopdemo.entity;

import javax.persistence.*;

/**
 * @author qx
 * @date 2024/2/4
 * @des 访问情况实体
 */
@Entity
@Table(name = "t_visit")
public class Visit {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    /**
     * 方法名称
     */
    private String methodName;

    /**
     * 请求路径
     */
    private String url;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getMethodName() {
        return methodName;
    }

    public void setMethodName(String methodName) {
        this.methodName = methodName;
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }
}
package com.example.aopdemo.repository;

import com.example.aopdemo.entity.Visit;
import org.springframework.data.jpa.repository.JpaRepository;

/**
 * @author qx
 * @date 2024/2/4
 * @des 访问请求持久层
 */
public interface VisitRepository extends JpaRepository<Visit, Long> {
}

六、创建切面

package com.example.aopdemo.aspect;

import com.example.aopdemo.entity.Visit;
import com.example.aopdemo.repository.VisitRepository;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

/**
 * @author qx
 * @date 2024/2/4
 * @des 方法访问切面
 */
@Aspect
@Component
public class VisitCountAspect {

    @Autowired
    private VisitRepository visitRepository;

    @Around("@annotation(com.example.aopdemo.annotation.VisitCount)")
    public Object VisitCountAround(ProceedingJoinPoint joinPoint) throws Throwable {
        // 获取当前请求的URL
        String url = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest().getRequestURL().toString();
        // 方法名
        String methodName = joinPoint.getSignature().getName();

        // 保存访问数据
        Visit visit = new Visit();
        visit.setUrl(url);
        visit.setMethodName(methodName);
        visitRepository.save(visit);
        return joinPoint.proceed();
    }

}

七、创建控制层并添加注解

package com.example.aopdemo.controller;

import com.example.aopdemo.annotation.VisitCount;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author qx
 * @date 2024/2/4
 * @des
 */
@RestController
@RequestMapping("/index")
public class IndexController {

    @GetMapping("/one")
    @VisitCount
    public String showOne() {
        return "one";
    }

    @GetMapping("/two")
    @VisitCount
    public String showTwo() {
        return "two";
    }
}

八、测试

启动程序,在浏览器上访问请求地址。

SpringBoot Aop实现接口请求次数统计_spring

我们刷新数据库,发现新增了数据。这样我们就可以根据自己的需求获取请求次数。

SpringBoot Aop实现接口请求次数统计_aop_02

到此这篇关于SpringBoot Aop实现接口请求次数统计的文章就介绍到这了,更多相关SpringBoot Aop接口请求次数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • 详解Java并发编程之volatile关键字

    详解Java并发编程之volatile关键字

    这篇文章主要为大家介绍了Java并发编程之volatile关键字,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • Java8中CompletableFuture的用法全解

    Java8中CompletableFuture的用法全解

    这篇文章主要给大家介绍了关于Java8中CompletableFuture用法的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • java开发分布式服务框架Dubbo服务引用过程详解

    java开发分布式服务框架Dubbo服务引用过程详解

    这篇文章主要为大家介绍了java开发分布式服务框架Dubbo服务引用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-11-11
  • 关于spring属性占位符用法

    关于spring属性占位符用法

    这篇文章主要介绍了关于spring属性占位符用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • java发送邮件示例讲解

    java发送邮件示例讲解

    这篇文章主要为大家详细介绍了java发送邮件示例的全过程,温习邮件协议,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • MyBatis使用<foreach>标签like查询报错解决问题

    MyBatis使用<foreach>标签like查询报错解决问题

    这篇文章主要介绍了MyBatis使用<foreach>标签like查询报错解决问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • mybatis调用存储过程的实例代码

    mybatis调用存储过程的实例代码

    这篇文章主要介绍了mybatis调用存储过程的实例,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-10-10
  • 如何通过XML方式配置并实现Mybatis

    如何通过XML方式配置并实现Mybatis

    这篇文章主要介绍了如何通过XML方式配置并实现Mybatis,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 如何在Spring Boot中使用OAuth2认证和授权

    如何在Spring Boot中使用OAuth2认证和授权

    这篇文章主要介绍了如何在Spring Boot中使用OAuth2认证和授权的相关资料,OAuth2.0是一种开放的授权协议,它允许用户授权第三方应用访问其账户(或资源),而无需共享其用户账户凭据,需要的朋友可以参考下
    2023-12-12
  • Spring boot整合mybatis实现过程图解

    Spring boot整合mybatis实现过程图解

    这篇文章主要介绍了Spring boot整合mybatis实现过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08

最新评论