代码Service方法都报 Parameter 0 of constructor in com.fan.xx required a single bean, but 2 were found原因分析

今天遇到一个问题,拉取同事的代码,发现编译不过,报错如下:

***************************
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)

即可解决。

这是一般开发不注意最容易遇到的问题,特记录下,有遇到的同学可以按照上述方法快速排查下。


版权声明:本文为fanfuqiang原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。