利用SpringMVC的AOP来实现后台系统的操作日志记录

最近在项目中要求把后台的一些关键操作记录下来,想了好半天能想到的也就那两三种方式,要么就是写一个拦截器,然后再web.xml里面进行配置,要么就是就是在每个需要记录操作日志的代码里面进行拦截,最后我选择了第三种,也就是基于AOP的拦截,用这种方式,只需要在需记录操作的接口方法上,添加上自定义注解就好了。其实在项目开发里面真正用到AOP感觉不是很多,我也一样很少就没有怎么用到。刚好这次碰见了,就记录下来,也算是自己学习一次。
我在做的项目是基于SSH(Spring,Spring MVC,Hibernate)框架。

  1. 首先我们先想想我们做的功能到底是什么,我们要记录操作,我们首先就应该有一张记录操作记录的表
  `@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
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

604673868

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值