spring-boot-route 使用aop记录操作日志,netty源码剖析与实战百度云

private Date operTime;

}

二 自定义注解及处理

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

自定义注解包含两个属性,一个是业务模块 title ,另一个是操作类型 businessType 。

@Target({ ElementType.PARAMETER, ElementType.METHOD })

@Retention(RetentionPolicy.RUNTIME)

@Documented

public @interface Log {

/**

  • 模块

*/

String title() default “”;

/**

  • 功能

*/

BusinessType businessType() default BusinessType.OTHER;

}

使用aop对自定义的注解进行处理

@Aspect

@Component

@Slf4j

public class LogAspect {

@Autowired

private AsyncLogService asyncLogService;

// 配置织入点

@Pointcut("@annotation(com.javatrip.aop.annotation.Log)")

public void logPointCut() {}

/**

  • 处理完请求后执行

  • @param joinPoint 切点

*/

@AfterReturning(pointcut = “logPointCut()”, returning = “jsonResult”)

public void doAfterReturning(JoinPoint joinPoint, Object jsonResult) {

handleLog(joinPoint, null, jsonResult);

}

/**

  • 拦截异常操作

  • @param joinPoint 切点

  • @param e 异常

*/

@AfterThrowing(value = “logPointCut()”, throwing = “e”)

public void doAfterThrowing(JoinPoint joinPoint, Exception e) {

handleLog(joinPoint, e, null);

}

protected void handleLog(final JoinPoint joinPoint, final Exception e, Object jsonResult) {

try {

// 获得注解

Log controllerLog = getAnnotationLog(joinPoint);

if (controllerLog == null) {

return;

}

SysOperLog operLog = new SysOperLog();

operLog.setStatus(0);

if (e != null) {

operLog.setStatus(1);

operLog.setErrorMsg(StringUtils.substring(e.getMessage(), 0, 2000));

}

// 设置方法名称

String className = joinPoint.getTarget().getClass().getName();

String methodName = joinPoint.getSignature().getName();

operLog.setMethod(className + “.” + methodName + “()”);

// 处理设置注解上的参数

getControllerMethodDescription(joinPoint, controllerLog, operLog);

// 保存数据库

asyncLogService.saveSysLog(operLog);

} catch (Excepti

【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】

浏览器打开:qq.cn.hn/FTf 开源分享

on exp) {

log.error(“前置通知异常”);

log.error(“日志异常信息 {}”, exp);

}

}

/**

  • 获取注解中对方法的描述信息 用于Controller层注解

  • @param log 日志

  • @param operLog 操作日志

  • @throws Exception

*/

public void getControllerMethodDescription(JoinPoint joinPoint, Log log, SysOperLog operLog) {

// 设置action动作

operLog.setBusinessType(log.businessType().ordinal());

// 设置标题

operLog.setTitle(log.title());

}

/**

  • 是否存在注解,如果存在就获取

*/

private Log getAnnotationLog(JoinPoint joinPoint) {

Signature signature = joinPoint.getSignature();

MethodSignature methodSignature = (MethodSignature) signature;

Method method = methodSignature.getMethod();

if (method != null) {

return method.getAnnotation(Log.class);

}

return null;

}

}

操作类型的枚举类:

public enum BusinessType {

/**

  • 其它

*/

OTHER,

/**

  • 新增

*/

INSERT,

/**

  • 修改

*/

UPDATE,

/**

  • 删除

*/

DELETE,

}

使用 异步 方法将操作日志存库,为了方便我直接使用jdbcTemplate在service中进行存库操作。

@Service

public class AsyncLogService {

@Autowired

private JdbcTemplate jdbcTemplate;

/**

  • 保存系统日志记录

*/

@Async

public void saveSysLog(SysOperLog log) {

String sql = “INSERT INTO sys_oper_log(title,business_type,method,STATUS,error_msg,oper_time) VALUES(?,?,?,?,?,?)”;

jdbcTemplate.update(sql,new Object[]{log.getTitle(),log.getBusinessType(),log.getMethod(),log.getStatus(),log.getErrorMsg(),new Date()});

}

}

三 编写接口测试

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

将自定义注解写在业务方法上,测试效果

@RestController

@RequestMapping(“person”)

public class PersonController {

@GetMapping("/{name}")

@Log(title = “system”,businessType = BusinessType.OTHER)

public Person getPerson(@PathVariable(“name”) String name, @RequestParam int age){

return new Person(name,age);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值