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"}) 项目可以正常启动

相关推荐
兮动人4 分钟前
获取终端外网IP地址
java·网络·网络协议·tcp/ip·获取终端外网ip地址
呆呆的小鳄鱼5 分钟前
cin,cin.get()等异同点[面试题系列]
java·算法·面试
独立开阀者_FwtCoder15 分钟前
"页面白屏了?别慌!前端工程师必备的排查技巧和面试攻略"
java·前端·javascript
Touper.20 分钟前
JavaSE -- 泛型详细介绍
java·开发语言·算法
静若繁花_jingjing37 分钟前
Redis线程模型
java·数据库·redis
hello早上好1 小时前
CGLIB代理核心原理
java·spring
魔镜魔镜_谁是世界上最漂亮的小仙女1 小时前
java-web开发
java·后端·架构
爱吃小土豆豆豆豆1 小时前
定时器和守护线程
java
Seven971 小时前
了解GC吗?什么是GC?
java
Edingbrugh.南空2 小时前
Flink ClickHouse 连接器维表源码深度解析
java·clickhouse·flink