Spring框架(十二):实现日志功能通过SpringBean后处理器
创始人
2024-03-18 16:56:42
0

实现日志功能通过SpringBean后处理器

  • 引子
  • 需求分析
  • 实现Log功能
  • Spring Bean的后置处理器

引子

痛定思痛,主要问题出现在自己雀氏不熟悉框架底层、一些面试题,以及sql的一些情况淡忘了。
本章节的开始是对于过去的重新回顾,当然,我也会深入基础,阅读源码,仔细熟悉开发过程,对问题进行整体学习,
后面会深入去做一些sql的题目来提升mysql能力
相关代码代码和笔记已经放到了gitee中去,喜欢的读者记得点赞下载
链接: BeanPostProcessor

需求分析

实现日志功能通过SpringBean后处理器
在这里插入图片描述

实现Log功能

Proxy.newProxyInstance 通过反射机制用来动态生成代理类对象, 为接口创建一个代理类,这个代理类实现这个接口。

@Component
public class MyBeanPostProcessor implements BeanPostProcessor {@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {//实现一个日志功能Object instance = Proxy.newProxyInstance(bean.getClass().getClassLoader(),bean.getClass().getInterfaces(),new InvocationHandler() {@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {Date startTime = new Date();System.out.println(method.getName() + " 日志开始记录" + " start_time: " + new Date());Object result = method.invoke(bean, args);System.out.println("日志开始记录" + method.getName() + " end_time: " + new Date());return result;}});return instance;}
}
  1. 调用 Proxy 类的 newProxyInstance方法来获取一个代理类实例。这个代理类实现了我们指定的接口并且会把方法调用分发到指定的调用处理器。

  2. 首先通过 newProxyInstance 方法获取代理类的实例,
    之后就可以通过这个代理类的实例调用代理类的方法,对代理类的方法调用都会调用中间类 (实现了 invocationHandle 的类) 的
    invoke 方法,在 invoke 方法中我们调用委托类的对应方法,然后加上自己的处理逻辑。

  3. java 动态代理最大的特点就是动态生成的代理类和委托类实现同一个接口。java
    动态代理其实内部是通过反射机制实现的,也就是已知的一个对象,在运行的时候动态调用它的方法,并且调用的时候还可以加一些自己的逻辑在里面。

@Configuration
@ComponentScan(basePackages = {"com.Iron"})
/*@PropertySource({"jdbc.properties"})*/
/*@Import(OtherBean.class)*/
/*@MapperScan("com.Iron.Mapper")*/
public class SpringConfig {}
@Service("userService")
public class UserServiceImpl implements UserService {public void call() {try {Thread.sleep(3000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("123");}
}
//@ComponentScan
public class Spring {public static void main(String[] args) throws InterruptedException {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);UserService userService = (UserService) context.getBean("userService");userService.call();
/*        Object myTestBean = cont.getBean("com.Iron.MyComponent.TestBean1");System.out.println(myTestBean);*/}
}

在这里插入图片描述

Spring Bean的后置处理器

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...