最近在项目中要求把后台的一些关键操作记录下来,想了好半天能想到的也就那两三种方式,要么就是写一个拦截器,然后再web.xml里面进行配置,要么就是就是在每个需要记录操作日志的代码里面进行拦截,最后我选择了第三种,也就是基于AOP的拦截,用这种方式,只需要在需记录操作的接口方法上,添加上自定义注解就好了。其实在项目开发里面真正用到AOP感觉不是很多,我也一样很少就没有怎么用到。刚好这次碰见了,就记录下来,也算是自己学习一次。
我在做的项目是基于SSH(Spring,Spring MVC,Hibernate)框架。
- 首先我们先想想我们做的功能到底是什么,我们要记录操作,我们首先就应该有一张记录操作记录的表。
`@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
@Entity
@Table(name = "表名")
public class LogModel extends IdEntity {
//用户
private User user;
//IP
private String remoteAddr;
//异常
private String exception;
//日志标题
private String title;
//请求地址
private String requestUri;
//日志类型
private String type;
//日志记录描述
private String description;
以上是我所用到的实体类
2. 关于实体类的Service层,Dao层,Impl等等我就不再这里过多叙述,无非就是一些与数据库操作挂钩的一些代码。
3. 自定义一个切面注解
@Target({ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MethodLog {
/**
* 该注解作用于方法上时需要备注信息
*/
String remarks() default "";
}
4. 接下来就是重点了,切面类的具体实现。
@Component
@Aspect
public class SystemLogAspect {
//这段代码调用了org.slf4j.LoggerFactory line:280
private static final