使用 @Resource
注入
Spring 还支持使用 JSR-250 @Resource
注解(jakarta.annotation.Resource
)在字段或 Bean 属性 setter 方法上进行注入。这是 Jakarta EE 中的常见模式:例如,在 JSF 管理的 Bean 和 JAX-WS 端点中。Spring 也支持这种模式来管理 Spring 管理的对象。
@Resource
带有一个 name 属性。默认情况下,Spring 将该值解释为要注入的 Bean 名称。换句话说,它遵循按名称语义,如下例所示
-
Java
-
Kotlin
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Resource(name="myMovieFinder") (1)
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
}
1 | 这行代码注入了一个 @Resource 。 |
class SimpleMovieLister {
@Resource(name="myMovieFinder") (1)
private lateinit var movieFinder:MovieFinder
}
1 | 这行代码注入了一个 @Resource 。 |
如果未明确指定名称,则默认名称将从字段名称或 setter 方法派生。对于字段,它采用字段名称。对于 setter 方法,它采用 bean 属性名称。以下示例将把名为 movieFinder
的 bean 注入其 setter 方法
-
Java
-
Kotlin
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Resource
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
}
class SimpleMovieLister {
@set:Resource
private lateinit var movieFinder: MovieFinder
}
使用注解提供的名称由 CommonAnnotationBeanPostProcessor 知道的 ApplicationContext 解析为 bean 名称。如果您显式配置 Spring 的 SimpleJndiBeanFactory ,则可以通过 JNDI 解析名称。但是,我们建议您依赖于默认行为并使用 Spring 的 JNDI 查找功能来保留间接级别。
|
在没有显式指定名称的 @Resource
使用的独占情况下,类似于 @Autowired
,@Resource
查找主要类型匹配而不是特定命名的 bean,并解析众所周知的可解析依赖项:BeanFactory
、ApplicationContext
、ResourceLoader
、ApplicationEventPublisher
和 MessageSource
接口。
因此,在以下示例中,customerPreferenceDao
字段首先查找名为“customerPreferenceDao”的 bean,然后回退到类型 CustomerPreferenceDao
的主要类型匹配
-
Java
-
Kotlin
public class MovieRecommender {
@Resource
private CustomerPreferenceDao customerPreferenceDao;
@Resource
private ApplicationContext context; (1)
public MovieRecommender() {
}
// ...
}
1 | context 字段根据已知的可解析依赖项类型注入:ApplicationContext 。 |
class MovieRecommender {
@Resource
private lateinit var customerPreferenceDao: CustomerPreferenceDao
@Resource
private lateinit var context: ApplicationContext (1)
// ...
}
1 | context 字段根据已知的可解析依赖项类型注入:ApplicationContext 。 |