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.*.*(..)) 为一个独立的匹配表达式,注解中只需要有一个即可

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

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

第二个 * 表示通配符

第三个 * 表示类名

第四个 * 表示方法名

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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 华为手机解锁码计算工具_华为高通全系列手机解锁工具

    华为手机解锁码计算工具_华为高通全系列手机解锁工具华为手机要解锁这个是真的是一个很头痛的问题,一是要申请解锁码二是要用一个特殊的解锁工具,可是现在好了,一键获取解锁码、解锁工具已经问世。华为高通全系列手机解锁工具可以在线获取解锁码,并直接开启解锁。适用于华为高通系列手机,这句话意思是说,这个解锁工具不只是适用于华为C8816电信版的解锁还适合华为大多数使用高通处理器的手机解锁。希望大家一次解锁成功!工具说明:(1)仅支持华为部分高通系列机型…

  • pycharm 2021  激活码【在线注册码/序列号/破解码】[通俗易懂]

    pycharm 2021  激活码【在线注册码/序列号/破解码】,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • Boost之LockFree[通俗易懂]

    Boost之LockFree[通俗易懂]Boost

  • 什么是Linux内核版本_linux内核深度解析

    什么是Linux内核版本_linux内核深度解析Linux内核版本有两种:稳定版和开发版,Linux内核版本号由3个数字组成:r.x.yr:目前发布的内核主版本。x:偶数表示稳定版本;奇数表示开发中版本。y:错误修补的次数。内核版本号每位都代表什么?以版本号为例:2.6.9-5.ELsmp,r:2,主版本号x:6,次版本号,表示稳定版本y:9,修订版本号,表示修改的次数头两个数字合在一齐可以描述内核系列。如…

  • 中国博士为什么会没有尊严

    最近经常看到一些博士在网上诉苦,感叹自己寒窗苦读了半辈子的说,依然没有能够摆脱贫困,还不如早年进城打工的放牛娃,甚至出现了考研考博不如读技校的说法。中国的博士到底是怎么啦,为什么都这么没有尊严的呢?

  • get请求的长度限制是多少_url长度限制为多少

    get请求的长度限制是多少_url长度限制为多少Httpget方法提交的数据大小长度并没有限制,Http协议规范没有对URL长度进行限制。目前说的get长度有限制,是特定的浏览器及服务器对它的限制。各种浏览器和服务器的最大处理能力如下:IE:对URL的最大限制为2083个字符,若超出这个数字,提交按钮没有任何反应。Firefox:对Firefox浏览器URL的长度限制为:65536个字符。Safari:URL最大长度限制为80000个字符。Opera:URL最大长度限制为190000个字符。Goog

发表回复

您的电子邮箱地址不会被公开。

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