首先我们为什么需要做日志管理,在现实的上线中我们经常会遇到系统出现异常或者问题。这个时候就马上打开CRT或者SSH连上服务器拿日子来分析。受网络的各种限制。于是我们就想为什么不能直接在管理后台查看报错的信息呢。于是日志管理就出现了。

         其次个人觉得做日志管理最好的是Aop,有的人也喜欢用拦截器。都可以,在此我重点介绍我的实现方式。

         Aop有的人说拦截不到Controller。有的人说想拦AnnotationMethodHandlerAdapter截到Controller必须得拦截org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter。

         首先Aop可以拦截到Controller的,这个是毋容置疑的其次须拦截AnnotationMethodHandlerAdapter也不是必须的。最起码我没有验证成功过这个。我的spring版本是4.0.3。

         Aop之所以有的人说拦截不到Controller是因为Controller被jdk代理了。我们只要把它交给cglib代理就可以了。

第一步定义两个注解:

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_拦截器

 SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_02

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_拦截器_03

  SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_04

 SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_05

  SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_06

 SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_07

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_spring_08

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_日志管理_09

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_拦截器_10

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_拦截器_11

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_服务器_12

 SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_显示不全_13

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_日志管理_14

 

 

 其中显示不全方法的补充:

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_spring_15

SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)_spring_16