|
此版本仍在开发中,尚未被视为稳定版。如需最新稳定版本,请使用 Spring Framework 7.0.6! |
使用 JSR-330 标准注解
Spring 提供对 JSR-330 标准依赖注入注解的支持,这些注解位于 jakarta.inject 包中。这些注解可选地用作 Spring 注解的替代方案。
要使用它们,您需要在类路径(classpath)中包含相关的 JAR 文件。例如,jakarta.inject 工件可在标准的 Maven 仓库中获取
(repo.maven.apache.org/maven2/jakarta/inject/jakarta.inject-api/2.0.0/),
|
如果你使用 Maven,可以将以下依赖项添加到你的
|
使用依赖注入的@Inject和@Named
您可以选择不使用 @Autowired 进行依赖注入,而是改用 @jakarta.inject.Inject,如下所示。
-
Java
-
Kotlin
import jakarta.inject.Inject;
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
public void listMovies() {
this.movieFinder.findMovies(...);
// ...
}
}
import jakarta.inject.Inject
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
fun listMovies() {
movieFinder.findMovies(...)
// ...
}
}
与 @Autowired 一样,你可以在字段级别、方法级别和构造函数参数级别使用 @Inject。
此外,作为 Spring 的 ObjectProvider 机制的替代方案,您可以选择将注入点声明为 jakarta.inject.Provider,从而通过 Provider.get() 调用按需访问作用域较短的 Bean,或延迟访问其他 Bean。以下示例提供了前述示例的一个变体。
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Provider;
public class SimpleMovieLister {
private Provider<MovieFinder> movieFinder;
@Inject
public void setMovieFinder(Provider<MovieFinder> movieFinder) {
this.movieFinder = movieFinder;
}
public void listMovies() {
this.movieFinder.get().findMovies(...);
// ...
}
}
import jakarta.inject.Inject
import jakarta.inject.Provider
class SimpleMovieLister {
@Inject
lateinit var movieFinder: Provider<MovieFinder>
fun listMovies() {
movieFinder.get().findMovies(...)
// ...
}
}
如果你想为应被注入的依赖项使用一个限定名称,可以选择使用 @Named 注解作为 Spring 的 @Qualifier 功能的替代方案,如下例所示。
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(@Named("main") MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
class SimpleMovieLister {
private lateinit var movieFinder: MovieFinder
@Inject
fun setMovieFinder(@Named("main") movieFinder: MovieFinder) {
this.movieFinder = movieFinder
}
// ...
}
与 @Autowired 一样,@Inject 也可以与 java.util.Optional 或 @Nullable 一起使用。这一点在此处更为适用,因为 @Inject 没有 required 属性。以下示例展示了如何将 @Inject 与 Optional、@Nullable 以及 Kotlin 对可空类型的内置支持结合使用。
import jakarta.inject.Inject;
import java.util.Optional;
public class SimpleMovieLister {
@Inject
public void setMovieFinder(Optional<MovieFinder> movieFinder) {
// ...
}
}
-
Java
-
Kotlin
import jakarta.inject.Inject;
import org.jspecify.annotations.Nullable;
public class SimpleMovieLister {
@Inject
public void setMovieFinder(@Nullable MovieFinder movieFinder) {
// ...
}
}
import jakarta.inject.Inject
class SimpleMovieLister {
@Inject
var movieFinder: MovieFinder? = null
}
@Named:的标准等效项@Component注解
你可以选择使用 @Component,而不是 @jakarta.inject.Named 或其他 Spring 刻板注解(stereotype annotations),如下例所示。
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
@Named("movieListener")
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
@Named("movieListener")
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
// ...
}
通常情况下,使用 @Component 或其他 Spring 刻板注解时不会显式指定组件的名称,@Named 也可以以类似的方式使用,如下例所示。
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
@Named
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
@Named
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
// ...
}
当你使用 @Named 时,可以像使用 Spring 注解一样以完全相同的方式进行组件扫描,如下例所示。
-
Java
-
Kotlin
@Configuration
@ComponentScan(basePackages = "org.example")
public class AppConfig {
// ...
}
@Configuration
@ComponentScan(basePackages = ["org.example"])
class AppConfig {
// ...
}
与 @Component 不同,JSR-330 的 @Named 注解不可组合。您应使用 Spring 的构造型(stereotype)模型来构建自定义的组件注解。 |
|
如果你使用的遗留系统仍然使用
此外,如果您希望将 |
JSR-330 标准注解的局限性
使用 JSR-330 标准注解时,您应当了解某些重要功能不可用,如下表所示。
| Spring | JSR-330 | JSR-330 限制/注解 |
|---|---|---|
|
|
|
|
|
JSR-330 并未提供一种可组合的模型,仅提供了一种标识命名组件的方式。 |
|
|
JSR-330 的默认作用域类似于 Spring 的 |
|
|
|
|
- |
无等效项 |
|
- |
无等效项 |
|
|
|