【Spring AOP切面实现系统操作日志】

本文介绍了如何使用Spring AOP来实现系统操作日志的记录,包括创建系统操作日志对象,获取用户信息实体,利用IP解析工具获取详细信息,以及核心代码在接口层的实现。
摘要由CSDN通过智能技术生成

Spring AOP切面实现系统操作日志


自定义注解,放置的目标位置

import java.lang.annotation.*;

@Target(ElementType.METHOD) //注解放置的目标位置,METHOD是可注解在方法级别上
@Retention(RetentionPolicy.RUNTIME) //注解在哪个阶段执行
@Documented
public @interface SysLog {
   
    String operContent() default  ""; // 内容

    String moduleName() default ""; // 模块名称

    String operType() default ""; // 操作类型(登录,增加,删除,修改,查询,查看...)

}

系统操作日志对象

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

import java.io.Serializable;
import java.time.LocalDateTime;

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("sys_operation_log")
@ApiModel(value="Log对象", description="系统操作日志")
public class SysOperationLog implements Serializable {
   

    private static final long serialVersionUID = 1L;

    @ApiModelProperty("设备ID")
    @TableId(value = "id", type = IdType.ASSIGN_ID)
    @JsonSerialize(using = ToStringSerializer.class)
    private Long id;

    @ApiModelProperty(value = "模块名称")
    @TableField("module_name")
    private String moduleName;

    @ApiModelProperty(value = "操作人ID")
    @TableField("user_id")
    private String userId;

    @ApiModelProperty(value = "操作类型")
    @TableField("oper_type")
    private String operType;

    @ApiModelProperty(value = "操作名称")
    @TableField("user_name")
    private String userName;

    @ApiModelProperty(value = "操作账号")
    @TableField("user_account")
    private String userAccount;

    @ApiModelProperty(value = "操作时间")
    @TableField("oper_time")
    private LocalDateTime operTime;

    @ApiModelProperty(value = "操作内容")
    @TableField("oper_content")
    private String operContent;

    @ApiModelProperty(value = "ip")
    @TableField(
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值