解决: org.springframework.beans.factory.BeanNotOfRequiredTypeException

本文深入探讨了在Spring框架中使用注解方式进行Bean注入时遇到的BeanNotOfRequiredTypeException异常,分析了该异常产生的原因及解决方案,包括正确配置Spring的动态代理机制和基于接口的编程方式。

错误信息:

    org.springframework.beans.factory.BeanNotOfRequiredTypeException: Bean named 'aisleService' must be of type [com.gdie.whlocation.service.impl.AisleService], but was actually of type [$Proxy38]

    这个问题出现的原因:一般在使用annotation的方式注入spring的bean 出现的,具体是由于spring采用代理的机制导致的,看使用的代码:

Java代码  

  1. 1. 使用类注入:  
  2. @Resource(name = "aisleService")  
  3. private AisleService aisleService;  
  4.   
  5. 2. 使用接口注入:  
  6. @Resource(name = "aisleService")  
  7. private IAisleService aisleService;  

代码1不能使用JDK的动态代理注入,原因是jdk的动态代理不支持类注入,只支持接口方式注入;

代码2可以使用jdk动态代理注入;

如果要使用代码1的方式,必须使用cglib代理;

当然了推荐使用代码2的方式,基于接口编程的方式!

 

关于spring动态代理的配置:

Xml代码  

  1. 1.使用aop配置:   
  2.     <aop:config proxy-target-class="false"> </aop:config>   
  3.   
  4. 2. aspectj配置:   
  5.     <aop:aspectj-autoproxy proxy-target-class="true"/>  
  6.       
  7. 3. 事务annotation配置:   
  8.     <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>  

3种配置,只要使用一种即可,设置proxy-target-class为true即使用cglib的方式代理对象。

 附:spring的aop代理判断逻辑:

Java代码  

  1. //org.springframework.aop.framework.DefaultAopProxyFactory     
  2.   
  3. //参数AdvisedSupport 是Spring AOP配置相关类     
  4.   
  5. public AopProxy createAopProxy(AdvisedSupport advisedSupport)     
  6.   
  7.         throws AopConfigException {     
  8.   
  9.     //在此判断使用JDK动态代理还是CGLIB代理     
  10.   
  11.     if (advisedSupport.isOptimize() || advisedSupport.isProxyTargetClass()     
  12.   
  13.             || hasNoUserSuppliedProxyInterfaces(advisedSupport)) {     
  14.   
  15.         if (!cglibAvailable) {     
  16.   
  17.             throw new AopConfigException(     
  18.   
  19.                     "Cannot proxy target class because CGLIB2 is not available. "    
  20.   
  21.                             + "Add CGLIB to the class path or specify proxy interfaces.");     
  22.   
  23.         }     
  24.   
  25.         return CglibProxyFactory.createCglibProxy(advisedSupport);     
  26.   
  27.     } else {     
  28.   
  29.         return new JdkDynamicAopProxy(advisedSupport);     
  30.   
  31.     }     
  32.   
  33. }  

Java,Spring,BeanNotOfRequiredTypeException

问题描述:

    今天在使用annotation或Resource的方式注入spring的bean 的时候出现了 org.springframework.beans.factory.BeanNotOfRequiredTypeException:错误

后来看了下spring的一些解释,是未正确使用spring采用的代理机制导致了这个错误。

代码

    @Resource

    private FormDefMappingService formDefMappingService;

代码

    @Autowired

    private FormDefMappingService formDefMappingService;

上述的代码在只有在项目 类命名唯一否则会出现上述错误,避免上述错误在

    1、检查在FormDefMappingServiceImpl是否添加@service的注解(项目中仅有一个FormDefMappingServiceImpl时可省略2、3步骤)

    2、FormDefMappingServiceImpl中@service中添加name(name在项目中必须唯一)

    3、在使用时@Resource或@Autowired(添加name需与@Qualifier结合)中,添加name(name与FormDefMappingServiceImpl中name相同)

代码

    @Resource(name="formDefMappingService")

    private FormDefMappingService formDefMappingService;

代码

     @Autowired(required=false)

     @Qualifier("formDefMappingService")     

     private FormDefMappingService formDefMappingService;

 

---------------

转载:https://blog.youkuaiyun.com/u014308482/article/details/53033847

2025-11-17T21:12:34.309+08:00 ERROR 34036 --- [ main] o.s.boot.SpringApplication : Application run failed org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'businessController': Unsatisfied dependency expressed through field 'businessService': Error creating bean with name 'businessServiceImpl': Unsatisfied dependency expressed through field 'logInfoMapper': Error creating bean with name 'logInfoMapper' defined in file [E:\java\notes\teacherNotes\笔记视频代码\第三阶段\分布式事务资料\分布式事务资料\fescar-parent\fescar-business\target\classes\com\atguigu\dao\LogInfoMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory': Error creating bean with name 'sqlSessionFactoryBean' defined in class path resource [com/atguigu/config/DataSourceProxyConfig.class]: Unsatisfied dependency expressed through method 'sqlSessionFactoryBean' parameter 0: Bean named 'seataDataSourceProxy' is expected to be of type 'io.seata.rm.datasource.SeataDataSourceProxy' but was actually of type 'com.alibaba.druid.pool.DruidDataSource$$SpringCGLIB$$0' at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:713) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:693) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:133) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:482) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1416) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:597) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:520) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:326) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:324) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:973) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:917) ~[spring-context-6.0.7.jar:6.0.7] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:584) ~[spring-context-6.0.7.jar:6.0.7] at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:146) ~[spring-boot-3.0.5.jar:3.0.5] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:732) ~[spring-boot-3.0.5.jar:3.0.5] at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:434) ~[spring-boot-3.0.5.jar:3.0.5] at org.springframework.boot.SpringApplication.run(SpringApplication.java:310) ~[spring-boot-3.0.5.jar:3.0.5] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1304) ~[spring-boot-3.0.5.jar:3.0.5] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1293) ~[spring-boot-3.0.5.jar:3.0.5] at com.atguigu.BusinessApplication.main(BusinessApplication.java:17) ~[classes/:na] Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'businessServiceImpl': Unsatisfied dependency expressed through field 'logInfoMapper': Error creating bean with name 'logInfoMapper' defined in file [E:\java\notes\teacherNotes\笔记视频代码\第三阶段\分布式事务资料\分布式事务资料\fescar-parent\fescar-business\target\classes\com\atguigu\dao\LogInfoMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory': Error creating bean with name 'sqlSessionFactoryBean' defined in class path resource [com/atguigu/config/DataSourceProxyConfig.class]: Unsatisfied dependency expressed through method 'sqlSessionFactoryBean' parameter 0: Bean named 'seataDataSourceProxy' is expected to be of type 'io.seata.rm.datasource.SeataDataSourceProxy' but was actually of type 'com.alibaba.druid.pool.DruidDataSource$$SpringCGLIB$$0' at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:713) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:693) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:133) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:482) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1416) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:597) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:520) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:326) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:324) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:254) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1417) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1337) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:710) ~[spring-beans-6.0.7.jar:6.0.7] ... 20 common frames omitted Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'logInfoMapper' defined in file [E:\java\notes\teacherNotes\笔记视频代码\第三阶段\分布式事务资料\分布式事务资料\fescar-parent\fescar-business\target\classes\com\atguigu\dao\LogInfoMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory': Error creating bean with name 'sqlSessionFactoryBean' defined in class path resource [com/atguigu/config/DataSourceProxyConfig.class]: Unsatisfied dependency expressed through method 'sqlSessionFactoryBean' parameter 0: Bean named 'seataDataSourceProxy' is expected to be of type 'io.seata.rm.datasource.SeataDataSourceProxy' but was actually of type 'com.alibaba.druid.pool.DruidDataSource$$SpringCGLIB$$0' at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1513) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1407) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:597) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:520) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:326) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:324) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:254) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1417) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1337) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:710) ~[spring-beans-6.0.7.jar:6.0.7] ... 34 common frames omitted Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'sqlSessionFactoryBean' defined in class path resource [com/atguigu/config/DataSourceProxyConfig.class]: Unsatisfied dependency expressed through method 'sqlSessionFactoryBean' parameter 0: Bean named 'seataDataSourceProxy' is expected to be of type 'io.seata.rm.datasource.SeataDataSourceProxy' but was actually of type 'com.alibaba.druid.pool.DruidDataSource$$SpringCGLIB$$0' at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:798) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:548) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1332) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1162) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:560) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:520) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:326) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:324) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:254) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1417) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1337) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1498) ~[spring-beans-6.0.7.jar:6.0.7] ... 45 common frames omitted Caused by: org.springframework.beans.factory.BeanNotOfRequiredTypeException: Bean named 'seataDataSourceProxy' is expected to be of type 'io.seata.rm.datasource.SeataDataSourceProxy' but was actually of type 'com.alibaba.druid.pool.DruidDataSource$$SpringCGLIB$$0' at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1427) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1337) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:885) ~[spring-beans-6.0.7.jar:6.0.7] at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:789) ~[spring-beans-6.0.7.jar:6.0.7] ... 58 common frames omitted
最新发布
11-18
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值