SpringBoot如何实现AOP日志处理

发布时间:2021-10-18 09:13:42 作者:小新
来源:亿速云 阅读:127

这篇文章主要介绍SpringBoot如何实现AOP日志处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

日志处理:

需求分析

日志处理需要记录的是:

  1. 请求的URL

  2. 访问者IP

  3. 调用的方法

  4. 传入的参数

  5. 返回的内容

上面的内容要求在控制台和日志中输出。

在学习这部分知识的时候,真的感觉收获很多,在之前Spring学习的aop只是初步了解,现在有了一些深入的理解。好记性不如烂笔头!

在日志处理这部分主要是aop的使用,通过切面的方式来整合到项目了,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

人话:Aop 在不改变原有代码的情况下 , 去增加新的功能

需要了解的:

通知(Advice)里面还有几种方法来帮助实现,这里我列举了该部分实现的方法:

  1. doBefore方法(方法前执行),需要注解@Before实现

  2. After方法(方法后执行),需要注解@After实现

  3. doAfterReturning方法,需要注解@AfterReturning实现

具体实现看后面部分。

重要部分:导入依赖

<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.9.4</version>
</dependency>

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

提醒:导入包以后,刷新下Maven,如果运行的时候找不到包,重启试试,网上有很多的解决方法(也试过),最后个人只是重启一下子再刷新下maven就可以使用了。

这里就没有给出解决方法,只是一个提醒。

实现过程:

创建一个类(LogAspect),将该类定义成一个切面(@Aspect)并且加入容器中(@Component)。

首先创建一个切入点,后面的Advice是建立在切入点上:

@Pointcut("execution(* com.blog.Controller..*.*(..))")
public void log(){}

整个表达式可以分为五个部分

1、execution():表达式主体。

2、第一个*号:表示返回类型,*号表示所有的类型。

3、包名:表示需要拦截的包名,后面的两个句点分别表示当前包和当前包的所有子包,com.blog.Controller包、子孙包下所有类的方法。

4、第二个*号:表示类名,*号表示所有的类。

5、*(..) :第三个星号表示方法名,*号表示所有的方法,后面括弧里面表示方法的参数,两个句点表示任何参数

定义完切入点后,处理前置通知和后置通知:

@Before("log()")
public void doBefore(JoinPoint joinPoint){
    System.out.println("在进入controller之前处理流-------------");
}
@After("log()")
public void doAfter(){
    System.out.println("在进入controller之后处理流-------------");
}
//在切入点return内容之后切入内容(可以用来对处理返回值做一些加工处理)
@AfterReturning(returning = "result",pointcut="log()")
public void doAfterReturning(Object result){
    logger.info("Return ------ {}",result );
}

通过上述的简单介绍,可以知道我们如果需要知道需求里面的要求,我们的重点应该放到前置通知里面,在流处理之前获取前端操作的信息。

核心代码如下:

//通过上下文来获取请求里面的信息
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

HttpServletRequest request = attributes.getRequest();
//获取封装了署名信息的对象,在该对象中可以获取到目标方法名,所属类的Class等信息(反射)
String classMethod = joinPoint.getSignature().getDeclaringTypeName()+","+joinPoint.getSignature().getName();
// 1. 获取URL
String url = request.getRequestURL().toString();
//2. 获取ip地址
String addr = request.getRemoteAddr();

/*创建一个类RequestData,来保存相关信息*/
RequestData requestData = new RequestData(
    url, addr, classMethod, joinPoint.getArgs()
);
//在控制台打印出来
logger.info("RequestData------{}",requestData);

创建的类是内部类(RequestData),只是封装一下需要打印的信息。

实验效果:

在进入controller之前处理流-------------
2021-08-15 15:19:43.923  INFO 9644 --- [nio-8080-exec-1] com.blog.AspectAop.LogAspect             : RequestData------RequestData{url='http://localhost:8080/', ipAddr='0:0:0:0:0:0:0:1', classMethod='com.blog.Controller.IndexController,index', args=[]}
2021-08-15 15:19:43.932  INFO 9644 --- [nio-8080-exec-1] com.blog.AspectAop.LogAspect             : Return ------ index
在进入controller之后处理流-------------

以上是“SpringBoot如何实现AOP日志处理”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. springboot 集成aop模块
  2. 如何实现springboot+aop+Lua分布式限流

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

springboot aop

上一篇:如何使用C++实现贪吃蛇游戏

下一篇:如何理解PyCharm使用pyQT5进行GUI开发的基本流程

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》