第14讲 --让Spring自动扫描和管理Bean

本文介绍Spring框架2.5版本中引入的自动扫描机制,该机制能在类路径下寻找特定注解的类并将其纳入Spring容器管理。文章详细解释了如何配置自动扫描、不同组件注解的区别及其使用方法。

 

 

通过在classpath自动扫描方式把组件纳入spring容器中管理
 
 
前面的例子我们都是使用XML的bean定义来配置组件。在一个稍大的项目中,通常会有上百个组件,如果这些这组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找及维护起来也不太方便。spring2.5为我们引入了组件自动扫描机制,他可以在类路径底下寻找标注了@Component、@Service、@Controller、@Repository注解的类,并把这些类纳入进spring容器中管理。它的作用和在xml文件中使用bean节点配置组件是一样的。要使用自动扫描机制,我们需要打开以下配置信息:
<beans xmlns=" http://www.springframework.org/schema/beans"
       xmlns:xsi=" http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context=" http://www.springframework.org/schema/context"
       xsi:schemaLocation=" http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-2.5.xsd">
          <context:component-scan base-package="cn.itcast"/>
</beans>
其中base-package为需要扫描的包(含子包)。
@Service用于标注业务层组件、 @Controller用于标注控制层组件(如struts中的action)、@Repository用于标注数据访问组件,即DAO组件。而@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
 
 
目前的spring 只是区分了以上注解,但是在底层没有具体实现上的区分
 
验证步骤:
 
(1) 修改beans.xml
<?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:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-2.5.xsd">
       


        
     <!-- 扫描 cn.com.xinli包下以及子包种有 @Service @Controller @Repository @Component
          注解的类,一旦发现,则将其纳入到spring容器中管理
     -->
	<context:component-scan base-package="cn.com.xinli"></context:component-scan>

</beans>

 
(2) 给两个类加上   @Service  注解 PersionDaoBean 和 PersionServiceBean
 
(3) 写测试方法,由于我们使用的spring的自动扫描 注入bean,在等到bean的时候,就无法知道bean的名字,这里有一个默认的规则,就是你要得到的bean的名字就是你注解的类的 类名第一个字符小写

 

 

ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
		PersionSevice ps=(PersionSevice)ctx.getBean("persionServiceBean");
		PersionDao pd=(PersionDao)ctx.getBean("persionDaoBean");
		System.out.println(ps);
		System.out.println(pd);

 

  

 
(4) 结果:
可见两个bean都被注入值了
注意:
a.我们也可以在注解中指定 bean的名字,以后根据注解指定名字得到bean  @Service("huxl")

b.我们也可以在注解中指定bean的 生成方式,默认是 单例 ,我们可以指定为 原型 @Service("huxl") @Scope("propotype")

c.也可以使用注解指定bean的初始化和销毁方法

 

                @PostConstruct
	public void init()
	{
		log.info("初始化资源");
	}
	@PreDestroy
	public void destory()
	{
		log.info("释放资源");
	}

 


 

 

 
【3D应力敏感度分析拓扑优化】【基于p-范数全局应力衡量的3D敏感度分析】基于伴随方法的有限元分析p-范数应力敏感度分析(Matlab代码实现)内容概要:本文档介绍了基于伴随方法的有限元分析与p-范数全局应力衡量的3D应力敏感度分析,并结合拓扑优化技术,提供了完整的Matlab代码实现方案。该方法通过有限元建模计算结构在载荷作用下的应力分布,采用p-范数对全局应力进行有效聚合,避免传统方法中应力约束过多的问题,进而利用伴随法高效求解设计变量对应力的敏感度,为结构优化提供关键梯度信息。整个流程涵盖了从有限元分析、应力评估到敏感度计算的核心环节,适用于复杂三维结构的轻量化与高强度设计。; 适合人群:具备有限元分析基础、拓扑优化背景及Matlab编程能力的研究生、科研人员与工程技术人员,尤其适合从事结构设计、力学仿真与多学科优化的相关从业者; 使用场景及目标:①用于实现高精度三维结构的应力约束拓扑优化;②帮助理解伴随法在敏感度分析中的应用原理与编程实现;③服务于科研复现、论文写作与工程项目中的结构性能提升需求; 阅读建议:建议读者结合有限元理论与优化算法知识,逐步调试Matlab代码,重点关注伴随方程的构建与p-范数的数值处理技巧,以深入掌握方法本质并实现个性化拓展。
Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled. 2025-08-11 2025-08-11 14:13:38.677 ERROR 7 --- [ main] o.s.boot.SpringApplication : Application run failed 2025-08-11 2025-08-11 org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'objectMapperConfigurer' defined in class path resource [springfox/documentation/spring/web/SpringfoxWebMvcConfiguration.class]: BeanPostProcessor before instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DynamicDataSourceAutoConfiguration': BeanPostProcessor before instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration': Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: warning no match for this type name: com.cnpc.product.analysis.controller.AnalysisController [Xlint:invalidAbsoluteTypeName] 2025-08-11 at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:512) ~[spring-beans-5.2.1.RELEASE.jar!/:5.2.1.RELEASE] 2025-08-11 at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:323) ~[spring-beans-5.2.1.RELEASE.jar!/:5.2.1.RELEASE] 2025-08-11 at org.springframework.beans.factory.support.AbstractBeanFactory$$Lambda$164/0x00000000300e3940.getObject(Unknown Source) ~[na:na] 2025-08-11 at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222) ~[spring-beans-5.2.1.RELEASE.jar!/:5.2.1.RELEASE] 2025-08-11 at org.springframework.beans.factory.support.AbstractBeanF
08-12
在启动 Spring Boot 应用时遇到 `BeanCreationException` 问题,尤其是在与 `DynamicDataSourceAutoConfiguration` `ProxyTransactionManagementConfiguration` 相关的情况下,通常涉及多个方面的配置问题。以下是对相关问题的分析可能的解决方案: ### 1. `DynamicDataSourceAutoConfiguration` 相关的 `BeanCreationException` `DynamicDataSourceAutoConfiguration` 是用于支持动态数据源切换的自动配置类,通常在引入如 `dynamic-datasource-spring-boot-starter` 等第三方库时启用。如果该配置类无法正确加载或缺少必要的依赖项,可能导致上下文启动失败。常见原因包括: - **未正确配置数据源信息**:确保在 `application.yml` 或 `application.properties` 中配置了多个数据源,并且格式正确。例如: ```yaml spring: datasource: dynamic: primary: master datasource: master: url: jdbc:mysql://localhost:3306/master_db username: root password: root slave1: url: jdbc:mysql://localhost:3306/slave1_db username: root password: root ``` - **依赖缺失**:确认项目中已正确引入动态数据源相关的依赖,如 `dynamic-datasource-spring-boot-starter`,并且版本兼容当前的 Spring Boot 版本 [^3]。 ### 2. `ProxyTransactionManagementConfiguration` 相关的嵌套异常 `ProxyTransactionManagementConfiguration` 是 Spring 事务管理的核心配置类之一,负责启用基于代理的事务管理。如果该类加载失败,可能的原因包括: - **缺少事务管理器**:如果项目中使用了事务管理功能,但未正确配置事务管理器(如 `PlatformTransactionManager`),可能导致该配置类无法初始化。 - **与 AOP 相关的依赖缺失**:Spring 的事务管理依赖于 AOP 功能,需确保项目中包含 `spring-boot-starter-aop` 或相关依赖 [^1]。 ### 3. `ObjectMapperConfigurer` 相关的 `BeanCreationException` `ObjectMapperConfigurer` 通常用于自定义 JSON 序列化/反序列化行为。如果该 Bean 创建失败,可能是因为: - **Jackson 配置冲突**:检查是否在配置类中错误地覆盖了 `ObjectMapper` 的默认行为,或者引入了不兼容的 Jackson 模块。 - **依赖版本不兼容**:确保项目中使用的 Jackson 库版本与 Spring Boot 版本兼容 [^2]。 ### 4. "Invalid Absolute Type Name" 警告与 `AnalysisController` 该警告通常表示 Spring扫描类时遇到类名解析问题,可能是由于类路径中存在重复的类名或错误的类引用。建议检查以下内容: - **类路径冲突**:确认项目中没有多个版本的 `AnalysisController` 类,或存在重复的依赖。 - **组件扫描配置问题**:检查 `@ComponentScan` 注解(或 `@SpringBootApplication` 中的默认扫描)是否覆盖了所有必要的包路径,避免遗漏或冗余的扫描范围。 ### 总结 启动失败的根本原因可能涉及多个配置问题的叠加。建议按照以下步骤进行排查: 1. 检查日志中完整的堆栈跟踪,定位具体的 `BeanCreationException` 信息。 2. 确保所有数据源配置正确,并且相关依赖已正确引入。 3. 验证事务管理 AOP 依赖是否完整。 4. 审查 `ObjectMapperConfigurer` 的实现,确保其配置不会导致 Jackson 初始化失败。 5. 检查类路径中是否存在重复或冲突的类。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值