在Java中,我们可以使用Spring AOP(面向切面编程)和自定义注解来统一处理日志。以下是一个简单的示例:
首先,我们创建一个自定义注解,用于标记需要记录日志的方法:
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
-
- @Target(ElementType.METHOD) //注解放置的目标位置,METHOD是可放在方法级别
- @Retention(RetentionPolicy.RUNTIME) //注解在哪个阶段执行
- public @interface LogAnnotation {
- String value() default ""; //注解的值
- }
然后,我们创建一个切面,用于处理标记了@LogAnnotation的方法:
- import org.aspectj.lang.ProceedingJoinPoint;
- import org.aspectj.lang.annotation.Around;
- import org.aspectj.lang.annotation.Aspect;
- import org.aspectj.lang.annotation.Pointcut;
- import org.springframework.stereotype.Component;
-
- @Aspect
- @Component
- public class LogAspect {
-
- @Pointcut("@annotation(com.yourpackage.LogAnnotation)") //指定自定义注解的路径
- public void pointcut() {}
-
- @Around("pointcut()")
- public Object around(ProceedingJoinPoint joinPoint) {
- Object result = null;
- try {
- System.out.println("开始执行方法,记录日志");
- result = joinPoint.proceed(); //执行方法
- System.out.println("方法执行结束,记录日志");
- } catch (Throwable e) {
- System.out.println("方法执行出错,记录日志");
- e.printStackTrace();
- }
- return result;
- }
- }
最后,我们在需要记录日志的方法上添加@LogAnnotation注解:
- public class SomeService {
-
- @LogAnnotation("执行某个操作")
- public void someMethod() {
- //...
- }
- }
这样,当someMethod方法被调用时,LogAspect中的around方法会被触发,从而实现日志的统一处理。