Spring注解@Service和@Qualifier

3 篇文章 0 订阅

@Qualifier,在使用Spring框架中@Autowired标签时默认情况下使用 @Autowired 注释进行自动注入时,Spring 容器中匹配的候选 Bean 数目必须有且仅有一个。
在使用Spring框架中@Autowired标签时默认情况下使用 @Autowired 注释进行自动注入时,Spring 容器中匹配的候选 Bean 数目必须有且仅有一个。当找不到一个匹配的 Bean 时,Spring 容器将抛BeanCreationException 异常,并指出必须至少拥有一个匹配的 Bean。Spring 允许我们通过 @Qualifier 注释指定注入 Bean 的名称,这样歧义就消除了。
结合使用@Qualifier 和@Autowired
@Qualifier("XXX") 中的 XX是 Bean 的名称,所以 @Autowired 和 @Qualifier 结合使用时,自动注入的策略就从 byType 转变成 byName 了。
@Autowired 可以对成员变量、方法以及构造函数进行注释,而 @Qualifier 的标注对象是成员变量、方法入参、构造函数入参。

另外,@Service和@Qualifier通常成对使用。

先说明下场景,代码如下:

有如下接口:

public interface EmployeeService {
    public EmployeeDto getEmployeeById(Long id);
}

 

同时有下述两个实现类 EmployeeServiceImpl和EmployeeServiceImpl1:

复制代码
@Service("service")
public class EmployeeServiceImpl implements EmployeeService {
    public EmployeeDto getEmployeeById(Long id) {
        return new EmployeeDto();
    }
}

@Service("service1")
public class EmployeeServiceImpl1 implements EmployeeService {
    public EmployeeDto getEmployeeById(Long id) {
        return new EmployeeDto();
    }
}
复制代码

 

调用代码如下:

复制代码
@Controller
@RequestMapping("/emplayee.do")
public class EmployeeInfoControl {
    
    @Autowired
    EmployeeService employeeService;
     
    @RequestMapping(params = "method=showEmplayeeInfo")
    public void showEmplayeeInfo(HttpServletRequest request, HttpServletResponse response, EmployeeDto dto) {
        #略
    }
}
复制代码

 

 

  在启动tomcat时报如下错误:

复制代码
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'employeeInfoControl': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: com.test.service.EmployeeService com.test.controller.EmployeeInfoControl.employeeService; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No unique bean of type [com.test.service.EmployeeService] is defined: expected single matching bean but found 2: [service1, service2]
复制代码

  其实报错信息已经说得很明确了,在autoware时,由于有两个类实现了EmployeeService接口,所以Spring不知道应该绑定哪个实现类,所以抛出了如上错误。

这个时候就要用到@Qualifier注解了,qualifier的意思是合格者,通过这个标示,表明了哪个实现类才是我们所需要的,我们修改调用代码,添加@Qualifier注解,需要注意的是@Qualifier的参数名称必须为我们之前定义@Service注解的名称之一!

复制代码
@Controller
@RequestMapping("/emplayee.do")
public class EmployeeInfoControl {
    
    @Autowired
    @Qualifier("service")
    EmployeeService employeeService;
    
    @RequestMapping(params = "method=showEmplayeeInfo")
    public void showEmplayeeInfo(HttpServletRequest request, HttpServletResponse response, EmployeeDto dto) {
        #略
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: @Qualifier注解Spring框架中的一个注解,用于解决依赖注入时的歧义性问题。当一个接口有多个实现类时,使用@Qualifier注解可以指定具体要注入哪一个实现类。例如: ``` public interface Animal { void say(); } @Service @Qualifier("cat") public class Cat implements Animal { @Override public void say() { System.out.println("喵喵喵"); } } @Service @Qualifier("dog") public class Dog implements Animal { @Override public void say() { System.out.println("汪汪汪"); } } @Controller public class AnimalController { @Autowired @Qualifier("cat") private Animal animal; // ... } ``` 在上面的例子中,Animal接口有两个实现类:Cat和Dog。在AnimalController中需要使用Animal类型的实例,但是由于Animal接口有多个实现类,如果不使用@Qualifier注解指定具体要注入哪一个实现类,Spring会抛出NoUniqueBeanDefinitionException异常。使用@Qualifier("cat")注解指定注入Cat实现类的实例,程序就不会抛出异常了。 ### 回答2: @Qualifier注解的作用在于标识一个被注入的依赖对象的限定符。当一个接口有多个具体实现类时,通过使用@Qualifier注解可以指定具体使用哪个实现类进行注入。 在Spring框架中,当多个实现类实现了同一个接口时,默认情况下无法确定要注入的实现类是哪个。此时,我们可以使用@Qualifier注解进行限定。通过在被注入的成员变量、构造函数参数或者方法参数上添加@Qualifier注解,并指定对应的value值,就可以告诉Spring容器注入该限定符对应的实现类。 例如,我们有一个接口Animal和两个实现类Cat和Dog,现在我们要在某个类中注入Animal接口的实现类。这时候,我们可以使用@Qualifier注解来标识具体注入哪个实现类。比如,我们可以定义两个限定符@Qualifier("cat")和@Qualifier("dog"),然后在注入的地方使用@Qualifier("cat")来指定注入Cat类的实例。 使用@Qualifier注解可以解决多个实现类注入的歧义问题,确保正确的实现类被注入。同时,@Qualifier也提供了更多的灵活性,可以根据具体的需求按需指定要注入的实现类,使代码更加清晰可读。 需要注意的是,@Qualifier注解是通过value属性指定限定符的名称,同时该名称需要与对应的Bean名称或其他限定符的值保持一致,否则会导致注入失败。 ### 回答3: @Qualifier注解的作用是用于解决Spring容器中存在多个相同类型的Bean时的自动装配问题。当一个接口有多个实现类或一个类有多个子类时,如果使用自动装配方式(如@Autowired或@Inject注解)将实例注入到目标对象中,会导致无法确定具体注入哪个实例的问题。这时就可以使用@Qualifier注解来配合自动装配注解使用。 @Qualifier注解可以用于字段、参数和方法上,通过指定具体的Bean名称或自定义的限定符来确定注入的实例。具体使用方式如下: 1. 字段上使用@Qualifier注解: ```java @Autowired @Qualifier("beanA") private BeanA bean; ``` 2. 方法的参数上使用@Qualifier注解: ```java @Autowired public void setBean(@Qualifier("beanA") BeanA bean) { this.bean = bean; } ``` 3. 方法上使用@Qualifier注解: ```java @Autowired @Qualifier("beanA") public void initBean(BeanA bean) { this.bean = bean; } ``` 通过在@Qualifier注解中指定具体的Bean名称或自定义的限定符,可以确保自动装配注解选择正确的实例进行注入。 需要注意的是,@Qualifier注解必须与自动装配注解(如@Autowired或@Inject)一起使用,才能生效。而且,在多个实例符合条件的情况下,如果没有使用@Qualifier注解Spring会采用默认的装配规则(如按照名称匹配),如果匹配成功则可以注入成功,否则会抛出异常。使用@Qualifier注解能够明确指定需要注入的实例,提高程序的可读性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值