dCardAlarmController required a single bean, but 2 were found:

关于后台项目启动报如下错误的解决办法

APPLICATION FAILED TO START

***************************

Description:

Field iSearchServiceImpl in com.sailing.di.controlalarmservice.ws.idcardAlarm.IdCardAlarmController required a single bean, but 2 were found:

  • cloudSearchServiceImpl: defined in file [D:\curretCode\DIPFB\server-control-alarm\target\classes\com\sailing\di\controlalarmservice\model\controlAlarm\service\impl\CloudSearchServiceImpl.class]

  • ICloudSearchService: defined in file [D:\curretCode\DIPFB\server-control-alarm\target\classes\com\sailing\di\controlalarmservice\model\controlAlarm\service\ICloudSearchService.class]

错误分析

根据提示,Controller中没办法自动注入ICloudSearchService。

@Autowired默认按照类型注入,根据提示,我的项目中这个类型的bean有两个,因此无法自动注入。

错误信息也给出了解决的办法:

1.把其中一个bean加上@Primary注解,就可以作为默认使用,

2.在注入的属性添加@Qualifier指定beanName,以明确使用哪一个bean

但我只写了一个接口的实现类,按预期只有一个bean,应该是没问题的。

原因

经过一圈排查,发现我在springboot的启动类上添加了注解@MapperScan("om.gdd.di.*")。

@MapperScan这个是注解是mybatis的Mapper扫描注解,并且我指定的扫描范围是com包。

mybatis扫描com下的接口,生成接口的实现类,注入到spring。

然后spring扫描到我编写的接口实现类,注入spring, 因此就有了两个bean。

解决办法

1.在springboot项目中建议直接在Mapper接口上添加@Mapper,不要使用@MapperScan。

  1. 若要使用@MapperScan注解,注意配置好扫描的范围,避免重复扫描注入spring bean导致出现上述问题。

建议使用第二种方式 指定mapperScan的扫描范围 @MapperScan(value = {"com.gdd.di.controlalarmservice.model.*.repository"})

由原来的 @MapperScan("om.sailing.di.*") 改为 @MapperScan(value = {"com.gdd.di.controlalarmservice.model.*.repository"}) 项目可以正常启动

相关推荐
用坏多个鼠标9 分钟前
Nacos和Nginx集群,项目启动失败问题
java·开发语言
TangKenny28 分钟前
基于EasyExcel的动态列映射读取方案
java·easyexcel
安冬的码畜日常30 分钟前
【JUnit实战3_19】第十章:用 Maven 3 运行 JUnit 测试(下)
java·测试工具·junit·单元测试·maven·junit5
lemon_sjdk40 分钟前
软件开发模式架构选择
java·架构·软件开发·前后端分离
董广明1 小时前
单元测试(JUnit、Mockito、PowerMock )
java·经验分享·junit·单元测试
Lisonseekpan1 小时前
Java Stream 流式编程
java·后端
沐浴露z1 小时前
Kafka Consumer 消费流程详解
java·分布式·kafka
程序员小假1 小时前
运行时有出现过什么异常?
java·后端
凤山老林1 小时前
还在用JDK8?JDK8升级JDK11:一次价值千万的升级指南
java·开发语言·jvm·spring boot·后端·jdk
lang201509282 小时前
Apache Maven 项目的开发指南
java·maven·apache