spring复习:(23)DefaultListableBeanFactory BeanPostProcessor不起作用

在使用DefaultListableBeanFactory加载XML配置文件时,BeanPostProcessor的代码没有执行,因为getBeanPostProcessors()返回的列表为空。而切换到使用ApplicationContext则可以正常工作。这表明问题可能出在BeanPostProcessor的注册或加载阶段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

配置文件:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:c="http://www.springframework.org/schema/c"
       xmlns:p="http://www.springframework.org/schema/p"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
  https://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="tju" class="cn.edu.tju.domain.MyInitObject">

    </bean>

    <bean id="fgh" class="cn.edu.tju.domain.MyPostProcessObject">

    </bean>

</beans>
package cn.edu.tju;

import cn.edu.tju.domain.MyInitObject;
import cn.edu.tju.domain.MyPostProcessObject;
import cn.edu.tju.domain.Student;
import org.springframework.beans.factory.support.BeanDefinitionReader;
import org.springframework.beans.factory.support.DefaultListableBeanFactory;
import org.springframework.beans.factory.xml.XmlBeanDefinitionReader;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;

import java.util.concurrent.locks.ReentrantLock;

public class Start16 {
    public static void main(String[] args) {
        Resource resource = new ClassPathResource("beans13.xml");
        DefaultListableBeanFactory factory = new DefaultListableBeanFactory();
        BeanDefinitionReader beanDefinitionReader = new XmlBeanDefinitionReader(factory);
        beanDefinitionReader.loadBeanDefinitions(resource);

        //ApplicationContext factory = new ClassPathXmlApplicationContext("beans13.xml");

        MyInitObject student = factory.getBean("tju", MyInitObject.class);



    }
}

这样写BeanPostProcessor的代码不执行。换成ApplicationContext的写法就可以。debug发现:用DefaultListableBeanFactory时,

	public List<BeanPostProcessor> getBeanPostProcessors() {
		return this.beanPostProcessors;
	}

这个方法返回的list 的size为0

### Spring 中解决允许循环依赖配置不生效的方法 当遇到 `spring boot` 循环依赖配置不起作用的情况时,可以考虑以下几个方面来排查并解决问题。 #### 配置文件中的设置 确保已经在应用程序的属性文件中启用了对循环引用的支持。可以在 `application.properties` 或者 `application.yml` 文件里加入如下配置: 对于 properties 格式的配置文件: ```properties spring.main.allow-circular-references=true ``` 而对于 yml 格式的配置文件,则应这样写: ```yaml spring: main: allow-circular-references: true ``` [^1] #### 使用 @Lazy 注解 如果上述方法仍然无法解决问题,那么可能是因为某些特定场景下默认机制不足以处理复杂的循环依赖关系。此时可以通过在其中一个 bean 的定义上加上 `@Lazy` 注解的方式延迟加载该 Bean 实例,从而绕过初始化阶段可能出现的问题。 ```java @Component public class ServiceA { private final ServiceB serviceB; public ServiceA(@Lazy ServiceB serviceB){ this.serviceB = serviceB; } } ``` [^2] #### 自定义BeanFactoryPostProcessor 另外一种解决方案是在项目中实现自定义的 `BeanFactoryPostProcessor` 接口,在其 `postProcessBeanFactory()` 方法内部通过编程方式调整容器的行为以支持更广泛的循环依赖情况。不过这种方式相对复杂一些,并不是所有情况下都适用。 ```java import org.springframework.beans.BeansException; import org.springframework.context.ApplicationContextInitializer; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.stereotype.Component; @Component public class CustomCircularDependencyResolver implements ApplicationContextInitializer<ConfigurableApplicationContext> { @Override public void initialize(ConfigurableApplicationContext applicationContext) throws BeansException { DefaultListableBeanFactory beanFactory = (DefaultListableBeanFactory)applicationContext.getBeanFactory(); beanFactory.setAllowRawInjectionDespiteWrapping(true); } } ``` [^3]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值