当前位置: 首页 > news >正文

Aop自定义注解生成日志

Aop自定义注解生成日志

1.编写自定义注解

//表示此注解可以标注在方法上
@Target(ElementType.METHOD)
//运行时生效
@Retention(RetentionPolicy.RUNTIME)
public @interface OpetionLog {//定义一个变量,可以接收参数String  value() default "";}

2.Controller

    @PostMapping("updatestate/{id}")@ApiOperation("更改科室启用状态")@OpetionLog("更改科室启用状态")public Result updateStatus(@PathVariable Integer id) throws UnknownHostException {log.info("修改科室启用状态");return departmentService.updateStatus(id);}

3.切面类(控制台日志)

@Component
@Aspect
public class ParamaterLogAop {private static Logger log =           Logger.getLogger(String.valueOf(ParamaterLogAop.class));private long start = 0;@Pointcut("execution(* com.aaa.controller.*.*(..))")//切面签名public  void  haha(){}@Before("haha()")public  void  before(JoinPoint point){ServletRequestAttributes requestAttributes = (ServletRequestAttributes)           RequestContextHolder.getRequestAttributes();HttpServletRequest request = requestAttributes.getRequest();HttpServletResponse response = requestAttributes.getResponse();String addr = request.getRemoteAddr();String uri = request.getRequestURI();Object[] args = point.getArgs();start = System.currentTimeMillis();log.info("===================请求的地址是:================="+addr);log.info("===================请求的路径是:================="+uri);log.info("===================请求的参数是:================="+ Arrays.toString(args));}@AfterReturning("haha()")public  void  after(){long end = System.currentTimeMillis();log.info("=================耗时================="+ (end-start));log.info("=================结束了=================");}
}

4.切面类(数据库日志表)

@Component
@Aspect
public class OptionsLogAop {@Resourceprivate HttpSession httpSession;@Resourceprivate LogsMapper logsMapper;@AfterReturning(pointcut = "@annotation(opetionLog)", returning = "result")public void insertLog(JoinPoint joinPoint, OpetionLog opetionLog, Result result) throws UnknownHostException {//获取日志信息//获取当前时间String logTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());//获取当前操作人ip地址String addr = InetAddress.getLocalHost().getHostAddress();//获取登录人员姓名String name = ((DoctorDTO)httpSession.getAttribute("doctor")).getName();//操作类型String operation = opetionLog.value();//操作数据Object[] args = joinPoint.getArgs();//操作结果String code = result.getCode().toString();//日志对象LogsDTO logsDTO = new LogsDTO(null, name, operation, logTime, addr, Arrays.toString(args), code);//插入数据库logsMapper.insertLogs(logsDTO);}
}

4.1LogsDTO

@Data
@AllArgsConstructor
@NoArgsConstructor
public class LogsDTO implements Serializable {private static final long serialVersionUID = -28616532886171515L;private Integer id;private String name;private String operation;private String time;private String addr;private String data;private String result;
}

4.2LogsMapper

int insertLogs(LogsDTO logsDTO);//Logsmapper.xml
<insert id="insertLogs">insert into logsvalues (null, #{name}, #{operation},#{time},#{addr},#{data},#{result})
</insert>

5.结果

5.1控制台

在这里插入图片描述

5.2数据库日志表

在这里插入图片描述

http://www.lryc.cn/news/217674.html

相关文章:

  • 虚幻引擎:RPC:远端调用
  • 涉及多种位运算操作混合类题目——通过加转三进制(扩大状态,不变枚举量):CF1033F
  • BIOS开发笔记 - DDR基础
  • 基于SpringBoot+Vue的旅游系统、前后端分离
  • 手动制作Docker容器镜像
  • WPF布局控件之WrapPanel布局
  • 实现自动接听电话
  • 计算机网络之网络层(全)
  • PS学习笔记合集
  • 汇总记录Python常用的基础内置方法
  • 基于Tensorflow卷积神经网络玉米病害识别系统(UI界面)
  • Execution failed for task ‘:keyboard_utils:compileDebugKotlin‘.
  • AC修炼计划(AtCoder Regular Contest 163)
  • 持续进化,快速转录,Faster-Whisper对视频进行双语字幕转录实践(Python3.10)
  • 【设计模式】第24节:行为型模式之“模板方法模式”
  • 【考研数学】数学“背诵手册”(二)| 线代及概率论部分
  • Android WMS——WindowState介绍(十三)
  • C/C++网络编程基础知识超详细讲解第二部分(系统性学习day12)
  • 【教3妹学编程-算法题】117. 填充每个节点的下一个右侧节点指针 II
  • window10 mysql8.0 修改端口port不生效
  • 欧盟网络安全威胁:虚假与错误信息
  • 006 Linux 进程的概念 | 获取进程的PID
  • 时序预测 | Python实现ARIMA-CNN-LSTM差分自回归移动平均模型结合卷积长短期记忆神经网络时间序列预测
  • 《异常检测——从经典算法到深度学习》23 TimesNet: 用于常规时间序列分析的时间二维变化模型
  • 计算机网络(59)
  • 【CSS】CSS基础知识扫盲
  • React中的状态管理
  • 【优选算法系列】【专题九链表】第一节.链表常用技巧和操作总结(2. 两数相加)
  • 上线Spring boot-若依项目
  • pinia简单使用