使用JSR-330标准注解
Spring 提供了对 JSR-330 标准 依赖注入 注解的支持,这些注解位于 javax.inject 包中。这些注解可以作为 Spring 注解的可选替代方案使用。
要使用它们,您需要在类路径中拥有相关的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,以便按需访问短作用域的bean或通过Provider.get()调用懒惰访问其他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(...)
// ...
}
}
如果您希望为应注入的依赖项使用限定名称,您可以选择使用@Qualifier注解作为Spring的@Autowired支持的替代方案,如下例所示。
-
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 注解
可以选择性地使用@jakarta.inject.Named,而不是@Component或其他Spring标记注解,如下例所示。
-
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 stereotype注解时,不指定组件的明确名称是非常常见的做法,而@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的原型模型来构建自定义组件注解。 |
|
如果您正在维护仍使用
此外,如果您希望在 |
JSR-330标准注解的限制
在使用 JSR-330 标准注解时,您应当了解某些重要特性是不可用的,具体如下表所示。
| Spring | JSR-330 | JSR-330 限制/注释 |
|---|---|---|
|
|
|
|
|
JSR-330 不提供可组合的模型,只提供一种标识命名组件的方式。 |
|
|
JSR-330的默认作用域类似于Spring的 |
|
|
|
|
- |
没有对应的条目 |
|
- |
没有对应的条目 |
|
|
|