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_state VARCHAR(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