zoukankan      html  css  js  c++  java
  • spring统一日志管理,切面(@Aspect),注解式日志管理

    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);
        }
        
    }

    参考:

    http://kld208.iteye.com/blog/1632935

    http://www.oschina.net/code/snippet_201779_53788

  • 相关阅读:
    [DNN模块] DNNPortalDownload_1_0_9a_PA(C#)汉化版
    我的第一个DNN皮肤
    调试DNN的方法
    DotNetNuke系列文章 Skin 與 Container 設計介紹
    DotNetNuke 語言包的上傳步驟
    pstools使用说明
    Android Prefence 总结
    android 来电自动接听和自动挂断
    Android 颜色选择器(ColorPicker)
    修改文件权限与归属
  • 原文地址:https://www.cnblogs.com/chihirotan/p/6228337.html
Copyright © 2011-2022 走看看