关于后台项目启动报如下错误的解决办法
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。
2. 若要使用@MapperScan注解,注意配置好扫描的范围,避免重复扫描注入spring bean导致出现上述问题。?? ?
建议使用第二种方式 ? 指定mapperScan的扫描范围 ?@MapperScan(value = {"com.gdd.di.controlalarmservice.model.*.repository"})
由原来的 @MapperScan("om.sailing.di.*") ?改为 @MapperScan(value = {"com.gdd.di.controlalarmservice.model.*.repository"}) 项目可以正常启动