使用 @Resource 进行注入
Spring 也支持通过在字段或 Bean 属性 setter 方法上使用 JSR-250 @Resource 注解 (jakarta.annotation.Resource) 进行注入。这在 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
}
注解提供的名称由 ApplicationContext 解析为 Bean 名称,而 CommonAnnotationBeanPostProcessor 知道该名称。如果您明确配置 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 进行注入。 |