SpringBoot通过Aop使用统一使用日志记录

Maven

org.springframework.boot

spring-boot-starter-aop

2.4.3

Gradle

implementation group: ‘org.springframework.boot’, name: ‘spring-boot-starter-aop’, version: ‘2.4.3’

2、面向切面原理,编写配置类横向扩展业务代码

=========================================================================================

  1. 我们需要在该类加上注解@Aspect@Component,表明该类为切面类,并且注入到Spring容器

  2. 在Springboot启动类添加注解@EnableAspectJAutoProxy,开始切面功能

如图

在这里插入图片描述

方法执行周期所用注解


我们可以通过注解来确定方法的执行周期。

  • @Before 方法执行之前

  • @After 方法执行之后

  • @AfterThrowing 抛出异常后执行

  • @AfterReturning 最后执行方法

  • @Around 环绕通知

现在我们需要确定在哪个业务方法增加日志。首先我们需要找到该方法

通过@Pointcut注解可以确定我们需要的切入点


@Pointcut(“execution( * com.mosukj.manage.controller.BuiPatientInfoController.add(…))”)

public void patientAdd(){}

使用以上方法,该切入点可以多次引用。

引用方法。我们只需要@After("patientAdd()")

方法参数对象JoinPoint:可以获取方法的所有参数以及等等一些方法的信息;

实例代码

@After(“patientAdd()”) //方法执行完之后执行,切入点为以上定义的方法patientAdd()

public void patientAdd(JoinPoint joinPoint){

Object[] args = joinPoint.getArgs();

HttpServletRequest request = (HttpServletRequest) args[0];

Long userId = getUserId(request);

Map param = (Map) args[2];

String patientName = param.get(“buiPatientInfo_patientName”).toString();

savelogs(userId, “添加了<”+patientName+“>患者”,51);

}

通过@Around环绕通知注解可以处理所执行方法之前/之后/抛异常的时候,我们都可以编写自己所需要执行的日志请求

实例:

@Around(“patientRecodedelete()”)

public void handleExceptionLog(ProceedingJoinPoint jp) throws Throwable {

//此处可以编写方法执行之前的业务代码

try {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

一次偶然,从朋友那里得到一份“java高分面试指南”,里面涵盖了25个分类的面试题以及详细的解析:JavaOOP、Java集合/泛型、Java中的IO与NIO、Java反射、Java序列化、Java注解、多线程&并发、JVM、Mysql、Redis、Memcached、MongoDB、Spring、Spring Boot、Spring Cloud、RabbitMQ、Dubbo 、MyBatis 、ZooKeeper 、数据结构、算法、Elasticsearch 、Kafka 、微服务、Linux。

这不,马上就要到招聘季了,很多朋友又开始准备“金三银四”的春招啦,那我想这份“java高分面试指南”应该起到不小的作用,所以今天想给大家分享一下。

image

请注意:关于这份“java高分面试指南”,每一个方向专题(25个)的题目这里几乎都会列举,在不看答案的情况下,大家可以自行测试一下水平 且由于篇幅原因,这边无法展示所有完整的答案解析
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
(25个)的题目这里几乎都会列举,在不看答案的情况下,大家可以自行测试一下水平 且由于篇幅原因,这边无法展示所有完整的答案解析
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

Spring Boot是一个用于构建独立的、生产级别的Spring应用程序的框架,它提供了丰富的功能和特性,方便开发人员快速搭建和开发项目。 在Spring Boot使用AOP(面向切面编程)可以实现将一些公共的功能逻辑代码从业务逻辑代码中解耦出来,提高代码的复用性和可维护性。通过AOP可以在方法的前后注入一些通用的逻辑,例如日志记录、异常处理、权限校验等。 其中,使用AOP进行结果的统一封装是很常见的需求。通过AOP可以在方法执行后对返回的结果进行封装,统一处理返回结果的格式,并可以对结果进行一些统一处理操作,例如添加统一的返回码、返回信息、返回时间等。 在Spring Boot使用AOP进行结果的统一封装可以按照以下步骤进行: 1. 创建一个切面(Aspect),通过在切面类上加上@Aspect注解标识该类是一个切面类。 2. 在切面类中定义一个切点(Pointcut),通过定义一个方法并添加@Pointcut注解来指定切入点。 3. 在切面类中定义一个通知(Advice),通过@Before、@After、@Around等注解来指定通知类型,并在通知方法中编写需要执行的逻辑。 4. 在通知方法中获取方法的返回结果,并进行相应的封装和处理。 5. 在Spring Boot的配置类中添加@EnableAspectJAutoProxy注解来启用AOP使用以上步骤可以实现对方法返回结果的统一封装,使得返回结果具有统一的格式和处理逻辑。这样可以提高代码的重用性和可维护性,并且可以在一处对结果进行集中处理,减少了代码的重复性,提高了开发效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值