step1 开启切面编程
    <!-- 开启切面编程(通过配置织入@Aspectj切面 )  -->
    <aop:aspectj-autoproxy/>
<aop:aspectj-autoproxy />有一个proxy-target-class属性,默认为false,表示使用jdk动态代理织入增强,当配为<aop:aspectj-autoproxy poxy-target-class="true"/>时,表示使用CGLib动态代理技术织入增强。不过即使proxy-target-class设置为false,如果目标类没有声明接口,则spring将自动使用CGLib动态代理。
step2 编写日志注解类
@Target({ElementType.PARAMETER, ElementType.METHOD})  
@Retention(RetentionPolicy.RUNTIME)  
@Documented  
public @interface SystemLog {
    public String description() default "";  
}
@Aspect
@Component
public class SystemLogAspect {
    @Pointcut("@annotation(com.tj.common.log.system.SystemLog)")
    public  void controllerAspect() {}  
    
    @Pointcut("@annotation(com.tj.common.log.system.SystemLog)")
    public  void serviceAspect() {} 
    
    @Pointcut("@annotation(com.tj.common.log.system.SystemLog)")
    public  void repositoryAspect() {} 
    
    @After("controllerAspect()")
    public void doBefore(JoinPoint joinPoint) {
        try {
            HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
            String ip = request.getRemoteAddr();
            String description = getControllerMethodDescription(joinPoint);
            Object obj = request.getSession().getAttribute("loginUser");
            LogUser user = new LogUser(null, null);
            /*对象obj中必须拥有属性account、userName*/
            BeanUtils.copyProperties(user, obj);
            if(StringUtils.isBlank(user.getAccount())){
                user = new LogUser("Anonymous", "匿名用户");
            }
        } catch (Exception e) {
            
        }
    } 
    
    @SuppressWarnings("rawtypes")
    private static String getControllerMethodDescription(JoinPoint joinPoint)  throws Exception {
        String targetName = joinPoint.getTarget().getClass().getName();
        String methodName = joinPoint.getSignature().getName();
        Object[] arguments = joinPoint.getArgs();
        Class targetClass = Class.forName(targetName);
        Method[] methods = targetClass.getMethods();
        String description = "";
        for (Method method : methods) {
            if (method.getName().equals(methodName)) {
                Class[] clazzs = method.getParameterTypes();
                if (clazzs.length == arguments.length) {
                    description = method.getAnnotation(SystemLog.class).description();
                    break;
                }
            }
        }
        return description;
    }
}
step2 日志记录
@CrossOrigin(maxAge = 3600)
@RestController
@RequestMapping(value = "/cxOrders")
public class CxOrderResources {
    
    @SystemLog(description="查询订单列表操作")
    @RequestMapping( value="/showData", method = RequestMethod.GET)
    public ResponseEntity<String> showData()throws ApplicationRuntimeException {
        return new ResponseEntity<String>("", HttpStatus.OK);
    }
    
}
参考:
 
        
