|
对于最新的稳定版本,请使用 Spring Framework 7.0.6! |
使用 JSR 330 标准注解
Spring 为 JSR-330 标准注解(依赖注入)提供了支持。这些注解的扫描方式与 Spring 注解相同。要使用它们,你需要在类路径中包含相关的 jar 包。
|
如果您使用 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。此外,您可以将注入点声明为 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
class SimpleMovieLister {
@Inject
lateinit var movieFinder: Provider<MovieFinder>
fun listMovies() {
movieFinder.get().findMovies(...)
// ...
}
}
如果您希望为应注入的依赖项使用限定名称,
应使用 @Named 注解,如下例所示:
-
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和
@Nullable:
public class SimpleMovieLister {
@Inject
public void setMovieFinder(Optional<MovieFinder> movieFinder) {
// ...
}
}
-
Java
-
Kotlin
public class SimpleMovieLister {
@Inject
public void setMovieFinder(@Nullable MovieFinder movieFinder) {
// ...
}
}
class SimpleMovieLister {
@Inject
var movieFinder: MovieFinder? = null
}
@Named 和 @ManagedBean:等同于 @Component 注解的标准等效方案
而不是 @Component,你可以使用 @jakarta.inject.Named 或 jakarta.annotation.ManagedBean,
如下面的示例所示:
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
@Named("movieListener") // @ManagedBean("movieListener") could be used as well
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") // @ManagedBean("movieListener") could be used as well
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
// ...
}
通常会不指定组件名称而直接使用 @Component。
@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 或 @ManagedBean 时,可以以与使用 Spring 注释相同的方式使用组件扫描,如下例所示:
-
Java
-
Kotlin
@Configuration
@ComponentScan(basePackages = "org.example")
public class AppConfig {
// ...
}
@Configuration
@ComponentScan(basePackages = ["org.example"])
class AppConfig {
// ...
}
与 @Component 不同,JSR-330 @Named 和 JSR-250 @ManagedBean
注解是不可组合的。你应该使用 Spring 的 stereotype 模型来构建自定义组件注解。 |
JSR-330标准注解的限制
当你使用标准注解时,你应该知道一些重要的功能是不可用的,如下表所示:
| Spring | jakarta.inject.* | jakarta.inject 限制/说明 |
|---|---|---|
@Autowired |
@Inject |
|
@Component |
@Named / @ManagedBean |
JSR-330 不提供可组合的模型,只提供一种标识命名组件的方式。 |
@Scope("singleton") |
@Singleton |
JSR-330的默认作用域类似于Spring的 |
@Qualifier |
@Qualifier / @Named |
|
@Value |
- |
没有对应的条目 |
@Lazy |
- |
没有对应的条目 |
ObjectFactory |
提供者 |
|