美文网首页
Spring AOP 日志管理

Spring AOP 日志管理

作者: Ludwigvan | 来源:发表于2017-11-10 14:02 被阅读104次

    最近公司项目需要进行日志的监控,需求是在一个系统中可以监控另外一个系统的运行日志,最终决定使用spring aop进行日志处理保存到库里面,然后再另一个系统中直接查询展示出来。(最开始也考虑是否需要用消息队列)。功能差不多已经完成了,现在来总结一下以便自己忘记。

    一、what is AOP?

    AOP (Aspect Orient Programming)面向切面编程:面向对象编程(OOP)是从静态角度考虑程序结构,面向切面编程(AOP)是从动态角度考虑程序运行过程。

    二、AOP 的作用?

    常常通过 AOP 来处理一些具有横切性质的系统性服务,如事物管理、安全检查、缓存、对象池管理、日志管理等,AOP 已经成为一种非常常用的解决方案。

    三、AOP 的原理?

    AOP 实际上是由目标类的代理类实现的AOP 代理其实是由AOP 框架动态生成的一个对象,该对象可作为目标对象使用。AOP 代理包含了目标对象的全部方法,但 AOP 代理中的方法与目标对象的方法存在差异,AOP 方法在特定切入点添加了增强处理,并回调了目标对象的方法

    四:Spring 中对AOP的支持?

    Spring有两大核心IOCAOP:IOC在java web项目中无时无刻不在使用。然而AOP用的比较少,的确也是一般的项目用的场所不多。事务控制基本都用,但却是Spring封装的不需要我们再去实现。Spring 中 AOP 代理由 Spring 的 IoC 容器负责生成、管理,其依赖关系也由 IoC 容器负责管理。因此,AOP 代理可以直接使用容器中的其他 Bean 实例作为目标,这种关系可由 IoC 容器的依赖注入提供。Spring 默认使用 Java 动态代理来创建 AOP 代理, 这样就可以为任何接口实例创建代理了。当需要代理的类不是代理接口的时候,Spring 自动会切换为使用 CGLIB 代理,也可强制使用 CGLIB。

    AOP 编程其实是很简单的事情。纵观 AOP 编程, 其中需要程序员参与的只有三个部分:

    定义普通业务组件。

    定义切入点,一个切入点可能横切多个业务组件。

    定义增强处理,增强处理就是在 AOP 框架为普通业务组件织入的处理动作。

    所以进行 AOP 编程的关键就是定义切入点和定义增强处理。一旦定义了合适的切入点和增强处理,AOP 框架将会自动生成 AOP 代理,即:代理对象的方法 = 增强处理 + 被代理对象的方法

    五:Spring中AOP 的实现?:

    方式一:基于 Annotation 的“零配置”方式:使用@Aspect、@Pointcut等 Annotation 来标注切入点和增强处理。

    方式二:基于 XML 配置文件的管理方式:使用 Spring 配置文件来定义切入点和增强点。

    这里用的是第一种方式来实现日志管理

    1、首先定义一个日志拦截注解:

    在我们需要记录日志的操作方法上加上这个注解;

    2、定义一个业务组件:

    3、定义切面:


    然后再springmvc 配置文件中加上:

    开启AOP即可。

    主要的东西都在截图中就不详细说明了。再提一句在定义切点的时候可以传参数。

    最后:个人博客已经搭好了下次就直接在博客上面记录笔记了。

    相关文章

      网友评论

          本文标题:Spring AOP 日志管理

          本文链接:https://www.haomeiwen.com/subject/uddbmxtx.html