JDK动态代理实现日志框架

首先,在项目包com.ay.test 下创建业务接口类BusinessClassService,具体代码如下:

BusinessC lassService 业务接口类可以理解为日常开发业务创建的接口类, 接口中有一个简 单的方法doSomeThing 。然后,开发业务类的实现类BusinessClassServiceImpl,具体代码如下:

实现类BusinessClassServicelmpl 实现了BusinessClassServ ice 接口, 并实现了doSomeThing 方法,在方法中打印“ do something ......” 。接着,开发日志接口类My Logger , 具体代码如下:

• savelntoMethodTime : 记录进入方法的时间。 • saveOutMethodTime : 记录退出方法的时间。 接口类MyLogger 开发完成之后,用MyLoggerlmpl 类实现它, 具体代码如下:

MyLoggerlmpl 类实现接口MyLogger , 并实现savelntoMethodTime 和saveOutMethodTime 方法,在方法内部打印进入/退出方法的时间。 最后, 实现最重要的类MyLoggerHandler , 具体代码如下:

• lnvocationHandler : 该接口中仅定义了一个方法: public Object invoke(Object obj, Method method, Object[] args) , 在使用时,第一个参数obj 一般是指代理类, method是 被代理的方法, args为该方法的参数数组。这个抽象方法在代理类中动态实现。 所有的代码开发完成之后,开发测试类MyLoggerTest 进行测试, 具体代码如下:

• Proxy . newProxylnstance :该类即为动态代理类, static Object newProxylnstance (ClassLoader loader, Class[] interfaces, JnvocationHandler h),返回代理类的一个实例,返 回后的代理类可以当作被代理类使用。在Proxy.new Proxy Instance方法中,共有以下三 个参数: • Classloader loader: targetObject.getClass().getClassLoader()目标对象通过getClass 方法获取类的所有信息后,调用getClassLoader()方法来获取类加载器。获取类力口载 器后,可以通过这个类型的加载器,在程序运行时,将生成的代理类力口载到JVM即 Java虚拟机中,以使运行时需要。 •Class[] interfaces: targetObject.getClass().getinterfaces()获取被代理类的所有接口信 息,以便于生成的代理类可以具有代理类接口中的所有方法。 • lnvocationHandler h : 使用动态代理是为了更好地扩展, 比如在方法之前做什么操 作,之后做什么操作,这个时候这些公共的操作可以统一交给代理类去做。此时需 要调用实现了InvocationHandler 类的一个回调方法。

运行测试类的ma in 方法,便可以在Intellij IDEA 控制台查看打印信息,具体信息如下:

以上就是利用动态代理模式实现简单的日志框架, 具体的结构如图

这里总结一下JDK 动态代理的一般实现步骤: ( l )创建一个实现InvocationHandler 接口的类MyLoggerHandler,它必须实现invoke 方法。 (2 )创建被代理的类BusinessClassService 以及接口BusinessClassServicelmpl 。 (3 )调用Proxy 的静态方法newProxyInstance ,创建一个代理类。 ( 4 )通过代理类调用方法。

spring aop实现日志框架

使用Spring AOP 的注解方式实现日志框架是非常简单的。首先,在配置文件 spring-mvc且nl 中添加配置, 具体代码如下:

 
  • 那些配置@aspectJ切面的bean创建 代理,织入切面。<aop : aspectj -autoproxy />有一个proxy-target-class属性,默认为fal se, 表示使用JDK动态代理织入增强,当配置poxy-target-class 为true 时,表示使用CGLib动态代理技术织入增强。不过即使设置proxy-target-class 为fa lse ,如果目标类没有声明接 口,则Spring将自动使用CGLib动态代理。

配置添加完成之后,要定义一个切面Loglnterceptor ,具体代码如下:

• @Aspect : 标识Loglntercepto r类为一个切面,供容器读取. • @Before : 在所拦截方法执行之前执行before 方法。 • @After:在所拦截方法执行之后执行after方法。 • @Around :可以同时在所拦截方法的前后执行一段逻辑。 • execution 切入点指示符:

表示在controller 包中定义的任意方法 的执行。execution 切入点指示符执行表达式的格式如下:

翻译为:

其中黑色字体部分不能省略,各部分都支持通配符“*”来匹配全部。比较特殊的为形参 表部分,其支持以下两种通配符:

例如:

下面举一些execution 的使用实例,具体内容见表3 -3 。

切面类Loglnterceptor 开发完成之后, 重新启动springmvc-mybatis-book 项目,项目成功启 动后,在浏览器输入网址: http: //localbost: 8080/user/findAll , 便可以在lntellij IDEA 开发工具的 控制台看到如下的打印信息:

文章出处:https://www.cnblogs.com/kinglead/p/10979392.html

框架退出的方法_AOP日志框架实现相关推荐

  1. (二):集成日志框架:springboot使用logback日志框架

    前言 项目中日志系统是必不可少的,目前比较流行的日志框架有log4j.logback等,可能大家还不知道,这两个框架的作者是同一个人,Logback旨在作为流行的log4j项目的后续版本,从而恢复lo ...

  2. 服务器日志文件中包含堆栈跟踪,日志框架 Logback 官方手册(第三章:Configuration)...

    以下内容翻译整理自logback官方手册,地址:logback官方手册 logback 配置 将日志请求插入应用程序代码需要相当多的计划和工作.观察表明,大约有4%的代码用于日志记录.因此,即使是一个 ...

  3. java 可视化系统操作日志_技术文 | 日志框架使用技巧分享

    原标题:技术文 | 日志框架使用技巧分享 日志的意义 对于一个应用程序来说日志记录是具有重要意义的. 日志通常用于线上问题追踪,协助定位业务问题或程序问题,以及基于日志的业务逻辑统计分析等. java ...

  4. 项目跑到到了日志警告就卡住了_java中的日志框架梳理(以故事的形式呈现)...

    日志算是java工具体系的一个知识点,但又是写代码的时候绕不过去的一个知识点,这篇文章主要是针对于小白,以故事的形式来对目前市场上常见的一些日志框架进行一个介绍和梳理. 阶段一: 从前有一个程序员,名 ...

  5. Java日志框架Slf4j+Log4j入门

    一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...

  6. java sl4j 日志_Java日志框架Slf4j+Log4j入门

    一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...

  7. 动手造轮子:写一个日志框架

    动手造轮子:写一个日志框架 Intro 日志框架有很多,比如 log4net / nlog / serilog / microsoft.extensions.logging 等,如何在切换日志框架的时 ...

  8. SLF4J和Logback日志框架详解

    SLF4J和Logback日志框架详解 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 本文讲述SLF4J和Logback日志框架.    SLF4J是一 ...

  9. spring boot—集成log4j2日志框架

    文章目录 市场上的日志框架 spring boot日志框架关系 移除默认日志框架 切换为log4j2日志框架 市场上的日志框架   1)日志门面最常用的是slf4j   2)日志实现最常用的是logb ...

最新文章

  1. 【CSS】多行溢出显示省略号
  2. linux sort -w32,WIN32汇编: 31.列表视图控件
  3. 二分法如何排查问题版本
  4. map、mapPartitions、mapPartitionsWithIndex区别在哪里?
  5. Android--使用VideoView播放视频
  6. java jdbc实验,实验八 Java-JDBC编程
  7. 机房收费系统合作版(一):开始团队合作之旅
  8. 201671010140. 2016-2017-2 《Java程序设计》java学习第十六周
  9. 电阻中联分压电路的计算
  10. 测试人员日常基本工作流程
  11. 谷歌浏览器刷新快捷键
  12. 原生微信小程序使用class 三元运算符实现多选案例
  13. php css下划线,CSS文字下划线的设置方法介绍
  14. 2021牛客寒假算法基础集训营1
  15. 计算机安装电脑程序怎么办理,电脑一开机就自动安装软件怎么办
  16. 论文笔记《End-to-End Training of Hybrid CNN-CRF Models for Stereo》用于立体评估的端到端训练的混合CNN-CRF模型
  17. Vectorworks 2022 mac(3D建模专用工具)v2022.SP3完美支持m1
  18. SQL 2017 SQLPS执行Add-SqlAvailabilityDatabase异常
  19. 【15】processing-三角函数(中文)
  20. android 重力感应和屏幕旋转关系

热门文章

  1. 语言 物品竞拍系统_【优加答疑】没有语言的孩子,该如何沟通?
  2. 兆比特每秒和兆字节每秒_号称100兆、200兆的宽带,为什么实际下载速度只有几MB?...
  3. 导师会指导改matlab程序吗,导师指导记录.docx
  4. Java+Selenium3.3.1环境搭建
  5. JsonCpp的简单使用方法
  6. java读取大txt文件_使用java读取txt里边的文件内容并获取大小(M).txt
  7. discuz登陆首页后提示style_1_commen.css,关于Discuz用户面板必须刷新才能显示登录状态的问题解决办法...
  8. java分表插件_fastmybatis编写分表插件
  9. 计算机协会科创部部长职责,学生会科创部工作计划
  10. 线程池每次用都创建吗_跳槽涨薪季面试题之多线程(三)