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的后置处理器

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

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...