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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 动态规划优缺点_巴西优化航空路线利用率

    动态规划优缺点_巴西优化航空路线利用率C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的道路在统计条数时也计为 1 条。C 国幅员辽阔,各地的资源分布情况各不相同,这就导致了同一种商品在不同城市的价格不一定相同。但是,同一种商品在同一个城市的买入价和卖出价始终是相同的。商人阿龙来到 C 国旅游。当他得知“同一种商品在不同城市的价格可能会不同”这一信息之后,便决定在旅游的同时,利用商品在

    2022年8月9日
    1
  • python py生成及调用pyc文件「建议收藏」

    python py生成及调用pyc文件「建议收藏」本文仅供学习交流使用,如侵立删!联系方式及demo下载见文末pythonpy文件中调用pyc文件1.生成pyc文件#目录下所有py文件生成pycimportcompileallcompileall.compile_dir(‘D:\python项目\ceshi’)#py生成pyc文件importpy_compilepy_compile.compile(‘proxy.py’)2.py文件调用pyc1.将生成的pyc文件名修改成和py文件一样(如:test_pay

    2022年6月15日
    59
  • ip地址分类和子网掩码「建议收藏」

    ip地址分类和子网掩码「建议收藏」ip地址分类和子网掩码1.ip地址分类A类网络的IP地址范围为1.0.0.1-127.255.255.254;第一个八位是网络地址后三个八位是主机地址。B类网络的IP地址范围为:128.1.0.1-191.255.255.254;第二个八位是网络地址,剩下的三个是主机地址。C类网络的IP地址范围为:192.0.1.1-223.255.255.254;第三个八位是网络地址,剩下的三个是…

    2022年6月7日
    39
  • c++与三菱plc通信_C语言编写的代码是

    c++与三菱plc通信_C语言编写的代码是FX系列作为三菱基本款的PLC,它们之间的通讯体例别离如下:CC-LINK,N:N网络连接,并联连接。1.CC-LINK连接CC-LINK连接图如下:三菱PLC通讯与编程实例!-1.jpg(21.71KB,下载次数:0)2018-6-103:01上传对应的PLC可为FX1N、FX1NC、FX2N、FX2NC、FX3U、FX3UC,因为在使用CC-LINK通讯时要扩展CC-LINK模块,…

    2022年9月10日
    0
  • 期货软件开发与平台搭建注意事项是什么_手机期货程序化交易软件

    期货软件开发与平台搭建注意事项是什么_手机期货程序化交易软件期货软件开发和期货平台搭建需要注意很多内容,关系到后期运营的是否正常稳定。现在市面上的很多的期货交易系统软件平台,基本都支持支持PC、安卓APP端,微信端、且具备风控系统、杠杆系统、交易系统、在线出入金、后台管理系统、代理系统、股票数据行情等功能。但是行业鱼龙混杂,并不是每一家开发公司都是靠谱的。加wx:“Zhangyoukeji001”发送相关演示版与报价!  作为投资者,要想拥有一个可靠的期货交易系统,需要注意以下几点:前期对期货系统软件的功能规划——针对期货系统软件,要有具体的规划方案,需

    2022年9月10日
    0
  • shell脚本快速入门之—–shell脚本练习100例!!!

    shell脚本快速入门之—–shell脚本练习100例!!!#!/bin/bashi=1foriin{1..254}doping-c2-w3-i0.3192.168.110.$i$>/dev/nullif[$?-eq0];thenecho”192.168.110.$iisyes”elseecho”192.168.110.$iisno”fileti++done

    2022年10月3日
    0

发表回复

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

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