手动依赖注入;AutowireCapableBeanFactory简述

2024-09-06 07:12

本文主要是介绍手动依赖注入;AutowireCapableBeanFactory简述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

spring boot虽然帮我们把bean的依赖注入基本都默认配置好了;但有些时候,业务场景中一些对象实例不在spring生命周期中,但是对象中的属性又需要被spring依赖注入(属性在spring容器管理中);

比如一些servlefilter类,其中的一些属性又需要依赖一些springbean

我遇到的情况是这样的,实现FactoryBean接口获取到的自定义bean因为没有参与springbean的初始化,所以FactoryBean.getBean获取到的bean是没有经过spring的依赖注入的,也就是bean里需要注入的属性都是空的

这个时候可以使用AutowireCapableBeanFactory对刚刚制造出来的对象手动让它经过spring的依赖注入

常用方法简述

org.springframework.beans.factory.config.AutowireCapableBeanFactory

  1. autowireBean(Object existingBean) 功能:自动装配给定的现有
    Bean。此方法会尝试根据现有的依赖关系自动装配 Bean 的属性。
    参数:existingBean - 需要自动装配的现有 Bean
    对象。 返回值:无。
  2. autowireBeanProperties(Object existingBean, int autowireMode, boolean dependent) 功能:自动装配给定的现有 Bean 的属性,使用指定的自动装配模式和依赖标志。
    参数: existingBean - 需要自动装配的现有 Bean 对象。 autowireMode - 自动装配模式,如
    AUTOWIRE_BY_NAME 或 AUTOWIRE_BY_TYPEdependent- 是否将现有Bean
    标记为依赖于自动装配过程中创建的任何其他 Bean
    返回值:无。
  3. initializeBean(Object existingBean, String beanName) 功能:初始化给定的现有
    Bean。这通常包括调用 Aware 接口的方法(如果实现了的话),以及调用任何 @PostConstruct 注解的方法。
    参数:existingBean - 需要初始化的现有 Bean 对象。 beanName - Bean 的名称。
    返回值:初始化后的 Bean
  4. applyBeanPostProcessorsAfterInitialization(Object existingBean, String beanName) 功能:在 Bean 初始化之后,应用所有已注册的 BeanPostProcessor 实例的
    postProcessAfterInitialization 方法。
    参数: existingBean - 需要处理的现有 Bean
    对象。 beanName - Bean 的名称。
    返回值:处理后的 Bean
  5. applyBeanPostProcessorsBeforeInitialization(Object existingBean, String beanName) 功能:在 Bean 初始化之前,应用所有已注册的 BeanPostProcessor 实例的
    postProcessBeforeInitialization 方法。
    参数: existingBean - 需要处理的现有 Bean
    对象。 beanName - Bean 的名称。
    返回值:处理后的 Bean
  6. createBean(String beanName, Class<?> beanClass, Object... args)
    功能:创建一个新的 Bean 实例,并使用给定的构造函数参数进行初始化。
    参数: beanName - 新 Bean 的名称。
    beanClass - Bean 的类。
    args - 构造函数参数。
    返回值:创建的新 Bean 实例。
  7. invokeInitMethods(String beanName, Object bean, Object[] specificArguments) 功能:调用 Bean 的初始化方法,这通常是 @PostConstruct 注解的方法或
    <bean init-method="..."> 配置中指定的方法。
    参数: beanName - Bean 的名称。 bean - Bean 的实例。 specificArguments - 初始化方法的特定参数。
    返回值:无。
  8. destroyBean(String beanName, Object bean) 功能:销毁给定的 Bean。这通常包括调用
    @PreDestroy 注解的方法或 <bean destroy-method="..."> 配置中指定的方法。
    参数:
    beanName - Bean 的名称。 bean - Bean 的实例。
    返回值:无。

这篇关于手动依赖注入;AutowireCapableBeanFactory简述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141352

相关文章

Spring AI Alibaba接入大模型时的依赖问题小结

《SpringAIAlibaba接入大模型时的依赖问题小结》文章介绍了如何在pom.xml文件中配置SpringAIAlibaba依赖,并提供了一个示例pom.xml文件,同时,建议将Maven仓... 目录(一)pom.XML文件:(二)application.yml配置文件(一)pom.xml文件:首

使用maven依赖详解

《使用maven依赖详解》本文主要介绍了Maven的基础知识,包括Maven的简介、仓库类型、常用命令、场景举例、指令总结、依赖范围、settings.xml说明等,同时,还详细讲解了Maven依赖的... 目录1. maven基础1.1 简介1.2 仓库类型1.3 常用命令1.4 场景举例1.5 指令总结

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、

python中poetry安装依赖

《python中poetry安装依赖》本文主要介绍了Poetry工具及其在Python项目中的安装和使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前言1. 为什么pip install poetry 会造成依赖冲突1.1 全局环境依赖混淆:1

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA