SpringBoot——AOP面向切面编程-swagger操作日志

SpringBoot——AOP面向切面编程-swagger操作日志SpringBoot——AOP面向切面编程-swagger操作日志

大家好,又见面了,我是你们的朋友全栈君。

在spring中的AOP是一个重要的部分,但是在工作中需要去自定义一个切面和切面的时候并不多(至少本人是这样的),以至于以前学的一些东西到现在都已经记不清了,所以现在来做一下记录。以便于以后再用到的时提个醒。

需求:在系统中我们要加入按钮级别的操作日志,实际上就是借口级别的操作日志,记录的信息为:xx调用了xx接口。

解决方案:我的策略是获取所调用接口的类注释 和 方法注释,然后将两个注释的内容拼在一下保存到数据库中。

步骤如下:

1.引入依赖

         <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

2.编写切点和切面

 package com.youyou.address.aop;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

/**
 * 添加操作日志
 *
 * @author 刘朋
 * <br/>date 2019-04-22
 */
@Aspect
@Component
public class Testaop {

    @Pointcut("execution(public * com.youyou.*.controller.*.*(..)) " +
            "|| execution( public * com.youyou.common.base.BaseController.*(..))" +
            "&&@annotation(io.swagger.annotations.ApiOperation)" )
    public void log() {}

    @Around("log()&&@annotation(apiOperation)")
    public Object around(ProceedingJoinPoint pjp, ApiOperation apiOperation) {
        Object result = null;
        try {
            //获取类对象
            Class<?> controller = pjp.getThis().getClass();
            //获取swagger接口对象
            Api annotation = controller.getAnnotation(Api.class);
            //获取类接口的内容
            String description = annotation.description();
            System.out.println("调用接口为:"+description +"-"+ apiOperation.value());
            //执行方法
            result = pjp.proceed();
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }

        return result;
    }


}

这里做一下解释下面的代码

 @Pointcut("execution(public * com.youyou.*.controller.*.*(..)) " +
            "|| execution( public * com.youyou.common.base.BaseController.*(..))" +
            "&&@annotation(io.swagger.annotations.ApiOperation)" )
 execution(public * com.youyou.*.controller.*.*(..)) 为一个独立的匹配表达式,注解中只需要有一个即可

写三个是为了增加一些匹配规则而一些

第一个 * 表示方法的返回值为任意类型,如果有需要我们 可以定义自己的类型

第二个 * 表示通配符

第三个 * 表示类名

第四个 * 表示方法名

(…)表示参数为任意数量

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106451.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 公安大数据平台应用与公安大数据建模「建议收藏」

    公安大数据平台应用与公安大数据建模「建议收藏」基于沃达德大数据平台,通过对海量数据采集、处理、存储、分析和数据挖掘,根据数据的特性,采用合适的可视化方式,将数据直观地展现出来,以帮助人们认识数据、理解数据,同时找出包含在海量数据中的规律或者信息。公安大数据主要由公安业务数据、地理信息数据、互联网数据等组成。通过沃达德大数据平台,对公安大数据进行信息提取、分析、数据挖掘和可视化,用于警情时空分布和时空演化、犯罪事件热点分析、关注对象的轨迹跟踪等多个公安业务领域,全面提升公安机关的整体工作效率。沃达德公安大数据平台,利用接警数据进行警情密度分析,以大数

    2022年6月6日
    202
  • traceroute 安装及使用

    traceroute 安装及使用1.pc端下载traceroute-2.1.0-6.fc28.x86_64.rpm文件;https://rpmfind.net/linux/rpm2html/search.php?query=traceroute(x86-64)2.将安装包上传到centos主机使用rz命令3.执行rpm-ivhtraceroute-2.1.0-6.fc28.x86_64.rpm命令进行安装4…

    2022年6月20日
    398
  • 第k短路径_利用标幺值进行短路计算

    第k短路径_利用标幺值进行短路计算给定一张 N 个点(编号 1,2…N),M 条边的有向图,求从起点 S 到终点 T 的第 K 短路的长度,路径允许重复经过点或边。注意: 每条最短路中至少要包含一条边。输入格式第一行包含两个整数 N 和 M。接下来 M 行,每行包含三个整数 A,B 和 L,表示点 A 与点 B 之间存在有向边,且边长为 L。最后一行包含三个整数 S,T 和 K,分别表示起点 S,终点 T 和第 K 短路。输出格式输出占一行,包含一个整数,表示第 K 短路的长度,如果第 K 短路不存在,则输出 −1。数据范围

    2022年8月9日
    6
  • curl_init php_宝塔php开启curl扩展

    curl_init php_宝塔php开启curl扩展安装某些PHP源码如CMSTOP时需求系统开启curl扩展,这需要修改PHP的配置,在Windows中只需简单三步。一、window下安装php_curl支持1.将PHP安装文件夹下的三个文件php_curl.dll(可能在ext文件夹中),libeay32.dll,ssleay32.dll复制到%windir%/system32下;2.打开php.ini(可能在PHP环境的安装目录下,默认…

    2022年10月9日
    5
  • mybatis 查询返回List集合、map集合、List<Map>集合[通俗易懂]

    mybatis 查询返回List集合、map集合、List<Map>集合[通俗易懂]主要是加上这一行:resultType=“java.lang.String” <!–查询所有的学生去向–> <selectid=”selectStudentDirection”resultType=”java.lang.String”> SELECTdirectionNamefromwork_direction </select>…

    2022年9月27日
    5
  • java中jvm面试题_mysql基础面试题及答案

    java中jvm面试题_mysql基础面试题及答案Jvm面试题及答案(Jvm面试题大全带答案)发现网上很多Jvm面试题及答案整理都没有答案,所以花了很长时间搜集,本套Jvm面试题大全,有大量经典的Jvm面试题以及答案,包含Jvm语言常见面试题、面试经验技巧等,应届生,实习生,企业工作过的,都可参考学习!如果不背Jvm面试题的答案,肯定面试会挂!这套Jvm面试题大全,希望对大家有帮助哈~博主已将以下这些面试题整理成了一个面试手册,是PDF版的1、ZGC了解吗?JDK11中加入的具有实验性质的低延迟垃圾收集器,目标是尽可能在不影响吞吐

    2022年8月28日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号