Spring @Qualifier 注释教程
最后修改于 2023 年 10 月 18 日
Spring @Qualifier 注释教程展示了如何在 Spring 应用程序中使用 @Qualifier 来区分 bean。
Spring 是一个流行的 Java 应用程序框架,用于创建企业级应用程序。
Spring @Qualifier 注释
@Qualifier
注释有助于在 Spring 无法区分 bean 引用时消除歧义。
Spring @Qualifier 示例
该应用程序有不同类型的消息 bean。我们使用 @Qualifier
来区分它们。
src ├───main │ ├───java │ │ └───com │ │ └───zetcode │ │ │ Application.java │ │ ├───bean │ │ │ IMessage.java │ │ │ Info.java │ │ │ Warning.java │ │ └───service │ │ MessageProducer.java │ └───resources │ logback.xml └───test └───java
这是项目结构。
pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.zetcode</groupId> <artifactId>qualifierannotation</artifactId> <version>1.0-SNAPSHOT</version> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>17</maven.compiler.source> <maven.compiler.target>17</maven.compiler.target> <spring-version>5.3.23</spring-version> </properties> <dependencies> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.4.0</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring-version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring-version}</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.codehaus.mojo</groupId> <artifactId>exec-maven-plugin</artifactId> <version>3.1.0</version> <configuration> <mainClass>com.zetcode.Application</mainClass> </configuration> </plugin> </plugins> </build> </project>
在 pom.xml
文件中,我们有基本的 Spring 依赖 spring-core
和 spring-context
,以及日志 logback-classic
依赖。
exec-maven-plugin
用于从 Maven 命令行执行 Spring 应用程序。
resources/logback.xml
<?xml version="1.0" encoding="UTF-8"?> <configuration> <logger name="org.springframework" level="ERROR"/> <logger name="com.zetcode" level="INFO"/> <appender name="consoleAppender" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <Pattern>%d{HH:mm:ss.SSS} [%thread] %blue(%-5level) %magenta(%logger{36}) - %msg %n </Pattern> </encoder> </appender> <root> <level value="INFO" /> <appender-ref ref="consoleAppender" /> </root> </configuration>
logback.xml
是 Logback 日志库的配置文件。
com/zetcode/bean/IMessage.java
package com.zetcode.bean; public interface IMessage { String getMessage(); }
IMessage
接口有一个方法声明。
com/zetcode/bean/Info.java
package com.zetcode.bean; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; @Component @Qualifier("info") public class Info implements IMessage { @Override public String getMessage() { return "This is an information message"; } }
该接口的第一个实现提供了一个信息消息。@Qualifier
用于标识 bean。
com/zetcode/bean/Warning.java
package com.zetcode.bean; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; @Component @Qualifier("warning") public class Warning implements IMessage { public String getMessage() { return "This is a warning message"; } }
第二个实现提供了一个警告消息。它也使用 @Qualifier
进行命名。
com/zetcode/service/MessageProducer.java
package com.zetcode.service; import com.zetcode.bean.IMessage; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Service; @Service public class MessageProducer { private static final Logger logger = LoggerFactory.getLogger(MessageProducer.class); @Autowired @Qualifier("info") private IMessage infoMessage; @Autowired @Qualifier("warning") private IMessage warningMessage; public void produce() { logger.info("{}", infoMessage.getMessage()); logger.warn("{}", warningMessage.getMessage()); } }
MessageProducer
注入了两个 IMessage
bean。为了区分它们,我们使用了 @Qualifier
注释。
com/zetcode/Application.java
package com.zetcode; import com.zetcode.service.MessageProducer; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.AnnotationConfigApplicationContext; import org.springframework.context.annotation.ComponentScan; @ComponentScan(basePackages = "com.zetcode.bean;com.zetcode.service") public class Application { private static final Logger logger = LoggerFactory.getLogger(Application.class); public static void main(String[] args) { logger.info("Application starting"); try (var ctx = new AnnotationConfigApplicationContext(Application.class)) { var messageProducer = (MessageProducer) ctx.getBean("messageProducer"); messageProducer.produce(); } } }
这是主应用程序类。它检索 messageProducer
bean 并调用其 produce
方法。
$ mvn -q exec:java 10:50:03.309 [com.zetcode.Application.main()] INFO com.zetcode.Application - Application starting 10:50:03.574 [com.zetcode.Application.main()] INFO com.zetcode.service.MessageProducer - This is an information message 10:50:03.574 [com.zetcode.Application.main()] WARN com.zetcode.service.MessageProducer - This is a warning message
我们运行应用程序。
在本文中,我们学习了 Spring 的 @Qualifier
注释。
作者
列出 所有 Spring 教程。