自学内容网 自学内容网

SpringBoot使用AspectJ的@Around注解实现AOP全局记录接口:请求日志、响应日志、异常日志

 Spring 面向切面编程(AOP),系列文章:

《Spring面向切面编程(AOP)的简单实例》

《Spring使用AspectJ的注解式实现AOP面向切面编程》

《SpringBoot使用AspectJ实现AOP记录接口:请求日志、响应日志、异常日志》

《SpringBoot使用AspectJ的@Around注解实现AOP全局记录接口:请求日志、响应日志、异常日志》 

1、AspectJ 框架 @Around 注解简介

@Around 是 AspectJ 框架中用于环绕通知(Around Advice)的注解。环绕通知是一种非常强大的通知类型,它允许你在目标方法执行前后插入自定义的行为,甚至可以决定是否继续执行目标方法或替换其返回值。

使用 @Around 注解时,需要注意以下几点:

异常处理:在环绕通知中,你必须处理或重新抛出任何在 joinPoint.proceed() 调用中抛出的异常。

性能影响:由于环绕通知可以在方法执行前后执行自定义逻辑,因此可能会对性能产生影响。在性能敏感的应用中,应谨慎使用。

关于 AspectJ 框架的详细使用方法,请求点击浏览文章:《Spring使用AspectJ的注解式实现AOP面向切面编程》

2、SpringBoot 使用 AspectJ 实现日志记录操作

【示例】SpringBoot 项目中使用 AspectJ 实现日志记录操作。

(1)创建数据库表

使用 MySQL 数据库,创建表 tbl_request_log(请求日志表)。

-- 创建数据表:tbl_request_log(请求日志表)
DROP TABLE IF EXISTS tbl_request_log;
CREATE TABLE IF NOT EXISTS tbl_request_log
( 
log_id BIGINT(20) AUTO_INCREMENT PRIMARY KEY COMMENT '日志ID(主键、自增)',
execute_stateVARCHAR(50) DEFAULT NULL COMMENT '执行状态(成功执行、发生异常)',
class_name VARCHAR(100) DEFAULT NULL COMMENT '所属类名',
method_name VARCHAR(100) DEFAULT NULL COMMENT '方法名称',
request_url VARCHAR(100) DEFAULT NULL COMMENT '请求地址',
request_method VARCHAR(50) DEFAULT NULL COMMENT '请求方式(GET、POST等)',
login_account VARCHAR(50) DEFAULT NULL COMMENT '登录账户',
ip_address VARCHAR(50) DEFAULT NULL COMMENT 'IP地址',
request_time TIMESTAMP DEFAULT CUR

原文地址:https://blog.csdn.net/pan_junbiao/article/details/143821279

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!