Springboot整合AOP和注解实现日志记录——Java入职第十二天

前言

        作为java开发工程师,日常curd工作少不了,特别是后台系统的操作,对于每一项操作我们都要记录,所以就得有操作日志,操作日志能够排除是开发的锅,是运营或者产品自己操作的。那么就有个问题,每次在业务处理最后,调用操作日志服务保存响应的日志,但是这段代码是很冗余的。

        其实想要解决这个问题,方法很多,可以用工厂模式,日志模板,日志切面等等。本讲就是利用Spring的AOP面向切面编程来实现日志操作,Sping官网也说了AOP主要用于日志,事务等处理,同时,自定义一个日志注解,那些业务操作需要记录日志,只要添加对应的注解就行,使得业务代码和日志代码低耦合。

一、AOP面向切面编程

        AOP(Aspect Oriented Programming,面向切面编程),可以说是 OOP(Object Oriented Programing,面向对象编程)的补充和完善。OOP 引入封装、继承和多态性等概念来建立一种对象层次结构,用来模拟公共行为的一个集合。当我们需要为分散的对象引入公共行为的时候,OOP则显得无能为力。也就是说,OOP 允许你定义从上到下的关系,但并不适合定义从左到右的关系。例如日志功能,日志代码往往水平地散布在所有对象层次中,而与它所散布到的对象的核心功能毫无关系。对于其他类型的代码,如权限管理、异常处理等也是如此

你可能感兴趣的:(Java后端开发,spring,boot,aspect,自定义注解,日志记录,aop)