今天遇到一个问题,拉取同事的代码,发现编译不过,报错如下:
***************************
APPLICATION FAILED TO START
***************************Description:
Parameter 0 of constructor in com.fan.system.controller.PypMemberController required a single bean, but 2 were found:
- pypMemberServiceImpl: defined in file [D:\Project\Java\xx-MgmtSerivce\xx-service\target\classes\com\fan\system\service\impl\PypMemberServiceImpl.class]
- IPypMemberService: defined in file [D:\Project\Java\xx-MgmtSerivce\xx-service\xx-mgmt\target\classes\com\fan\system\service\IPypMemberService.class]
排查了Service注入的使用的方式没有什么问题,也没有多个实现类。
当然按照编译器给出的提示,给实现类增加 @Primary 注解也是可以解决的,但这始终不是问题的根本的原因。
后来通过调试源码,发现居然是新模块MapperScan的问题:
@MapperScan(value = {"com.fan.system.*"})
public class FanApplication {
代码模块目录结构如下:
因为@MapperScan的范围为整个包下面了,所以导致service对应的实现类都被扫描生成一个Bean对象,即使已经用@Service注解也会再生成一个Bean对象。
Class<? extends Annotation> annotationClass() default Annotation.class;
后来代码调整为扫描指定的Mapper目录:
@MapperScan(value = {"com.fan.system.mapper"})
也可以调整为:
@MapperScan(value = {"com.fan.system.*"}, annotationClass = Mapper.class)
即可解决。
这是一般开发不注意最容易遇到的问题,特记录下,有遇到的同学可以按照上述方法快速排查下。