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)


相关推荐

  • gg修改器内购_gg修改器版本大全

    gg修改器内购_gg修改器版本大全时空猎人--各种修改提供人:我不特别首先下载GG修改器;准备好一个免root框架,安装好了后,打开免root框架把游戏和GG修改器添加到框架里面腾讯版的时空猎人,不需要过保护,选择进程就行,内存选择单个CA然后左下角保存这里教大家一个方法进入游戏,出现签到奖励版面,什么都不要动,打开gg,搜索你要的值,比如伤害数据0.12就搜索0.12最好不要锁定不然会出现无效情…

  • Java 技术体系简介

    Java 技术体系简介Java技术包含的所有内容:1、Java技术体系2、Java一次编译,到处运行Java技术的核心就是Java虚拟机,因为所有的Java程序都在虚拟机上运行。Java程序的运行需要Java虚拟机、JavaAPI和JavaClass文件的配合。Java虚拟机实例负责运行一个Java程序。当启动一个Java程序时,一个虚拟机实例就诞生了。当程序结束,这个虚拟机实例也就消亡。Java支持平台无关性、安全性和网络移动性。而Java平台由Java虚拟机和Java核心类所构成,它为纯Java程序提供了

  • Python中的取整、取余运算「建议收藏」

    Python中的取整、取余运算「建议收藏」1.取整运算在Python中取整运算的运算符为//,且取整运算的取整为向下取整,不进行四舍五入例:9//4=2,即9对4取整等于2-9//-4=2,因为-9÷-4=2.25,取整为2那么问题来了,9//-4等于多少呢?9//-4=-3,因为9÷-4应该等于-2.25,那么对-2.25向下取整,应该为-3,而不是-2,所以9//-4=-3那么-9//4呢?-9÷4也应该等于-2.25,所以向下取整,得到-9//4=-3总结:9//4=2-9//-4=29//-4=-3-9//4=-3

  • 缠中说禅 图解_缠中说禅图解

    缠中说禅 图解_缠中说禅图解博客原文图解分析示范显示,第一个绿箭头的那一笔,没有发生笔破坏,那必然要回落去完成线段的走势,这是理论上100%保证的。而92这一处,出现线段破坏,但该线段不能拉回85处,那么这就构成了85-88这1分钟中枢的第三类卖点,后面的继续下跌也是理论100%保证的。93处,标准的线段类背驰,这就意味着92这1分钟第三类卖点,将出现中枢扩展,至少形成一个1分钟中枢,这也是理论100%保证的。也就是说88-93的下跌已经完成,后面必然有一个针对这下跌的反弹。后面的演化,都如教科书般标准,学过本ID理论的,都知

  • 常见的功能系统与管理事项

    常见的功能系统与管理事项常见的功能系统与管理事项

  • php 该如何获取从百度搜索进入网站的关键词

    php 该如何获取从百度搜索进入网站的关键词

    2021年10月30日

发表回复

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

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