Spring注解_详解

简介: Spring注解_详解@Autowired 注释将 @Autowired 注释标注在成员变量上 import org.

@Autowired 注释

将 @Autowired 注释标注在成员变量上 

复制代码
 
   
import org.springframework.beans.factory.annotation.Autowired; public class Boss { @Autowired private Car car; @Autowired private Office office; … }
复制代码

 它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。

Spring 通过一个 BeanPostProcessor 对 @Autowired 进行解析,所以要让 @Autowired 起作用必须事先在 Spring 容器中声明AutowiredAnnotationBeanPostProcessor Bean。

复制代码
 
   
<!-- 该 BeanPostProcessor 将自动起作用,对标注 @Autowired 的 Bean 进行自动注入 -->
  < bean class ="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" />
复制代码

这样,当 Spring 容器启动时,AutowiredAnnotationBeanPostProcessor 将扫描 Spring 容器中所有 Bean,当发现 Bean 中拥有 @Autowired 注释时就找到和其匹配(默认按类型匹配)的 Bean,并注入到对应的地方中去。

按照上面的配置,Spring 将直接采用 Java 反射机制对 Boss 中的 car  office 这两个私有成员变量进行自动注入。

所以对成员变量使用 @Autowired 后,大可将它们的 setter 方法(setCar() 和 setOffice())从 Boss 中删除。

当然,也可以通过 @Autowired 对方法或构造函数进行标注,来看下面的代码:

将 @Autowired 注释标注在 Setter 方法上

复制代码
 
   
public class Boss { private Car car; private Office office; @Autowired public void setCar(Car car) { this.car = car; } @Autowired public void setOffice(Office office) { this.office = office; } … }
复制代码

这时,@Autowired 将查找被标注的方法的入参类型的 Bean,并调用方法自动注入这些 Bean。

将 @Autowired 注释标注在构造函数上

复制代码
 
   
public class Boss { private Car car; private Office office; @Autowired public Boss(Car car ,Office office){ this.car = car; this.office = office ; } … }
复制代码

由于 Boss() 构造函数有两个入参,分别是 car 和 office,@Autowired 将分别寻找和它们类型匹配的 Bean,将它们作为 Boss(Car car ,Office office) 的入参来创建 Boss Bean。

@Qualifier

当我们在 Spring 容器中配置了两个类型为 Office 类型的 Bean,当对 Boss 的 office 成员变量进行自动注入时,Spring 容器将无法确定到底要用哪一个 Bean,就会发生异常。

Spring 允许我们通过 @Qualifier 注释指定注入 Bean 的名称,这样歧义就消除了,可以通过下面的方法解决异常:

 
   
@Autowired public void setOffice(@Qualifier("office")Office office) { this.office = office; }

@Qualifier("office") 中的 office 是 Bean 的名称,所以 @Autowired 和 @Qualifier 结合使用时,自动注入的策略就从 byType 转变成 byName 了。

@Autowired 可以对成员变量、方法以及构造函数进行注释,而 @Qualifier 的标注对象是成员变量、方法入参、构造函数入参。正是由于注释对象的不同,所以 Spring 不将 @Autowired 和 @Qualifier 统一成一个注释类。

对成员变量使用 @Qualifier 注释

复制代码
 
   
public class Boss { @Autowired private Car car; @Autowired @Qualifier("office") private Office office; … }
复制代码

对构造函数变量使用 @Qualifier 注释 @Qualifier 只能和 @Autowired 结合使用,是对 @Autowired 有益的补充。一般来讲,@Qualifier 对方法签名中入参进行注释会降低代码的可读性,而对成员变量注释则相对好一些。

复制代码
 
   
public class Boss { private Car car; private Office office; @Autowired public Boss(Car car , @Qualifier("office")Office office){ this.car = car; this.office = office ; } }
复制代码

 @Controller

@Controller的基本目标是担任所注解的类的原型的角色,指明它的职责。Dispatcher将会在这样被注解的类中扫描映射的方法,探测注解@RequestMapping。

所注解的控制器bean可以被显式定义,这个过程是在Dispatcher的上下文中使用标准的Spring bean定义完成的。然而,@Controller原型也允许自动探测,要实现对所注解的控制器的自动探测,必须要向配置中加入组件扫描的部分。实现如下:

复制代码
 
   
<beans xsi:schemaLocation="   http: // www.springframework.org/schema/mvc http: // www.springframework.org/schema/mvc/spring-mvc-3.0.xsd http: // www.springframework.org/schema/beans http: // www.springframework.org/schema/beans/spring-beans-3.0.xsd http: // www.springframework.org/schema/context http: // www.springframework.org/schema/context/spring-context-3.0.xsd">
复制代码

 

@RequestMapping 

@RequestMapping是一种通过匹配URL路径来访问相应页面的

分类:类级别的和方法级别的

@RequestMapping的几种形式:

 
   
@RequestMapping(method = RequestMethod.GET) @RequestMapping(value="/{day}", method = RequestMethod.GET)//day为方法中的参数 @RequestMapping(value="/new", method = RequestMethod.GET)

将@RequestMapping放在类级别上这可令它与方法级别上的@RequestMapping注解协同工作,取得缩小选择范围的效果,如下:

复制代码
 
   
@RequestMapping("/a") // 类级别,可以不需要,如果要了,下面所有的请求路径前都需要加入 /a public class ccccontroller{ @RequestMapping("/b") // 方法级别,必须有,决定这个方法处理哪个请求,如果有类级别 /a/b     @RequestMapping(value="/b" method=RequestMethod.POST)     @RequestMapping(value="/b", method=RequestMethod.GET, params="type=checking")     @RequestMapping public String show() { // 如果没有类级别的就直接请求/b return; } }
复制代码

第一个是一种简写方式,匹配路径为 “/a/b”;

第二个方法级的请求映射和类级别的映射结合,当HTTP方法是POST时与路径“/a/b”匹配;

第三个添加了一个要求,就是名为“type”的请求参数和其值“checking”都需要在请求中出现;

第四个根本就没有指定路径,这个方法匹配所有的 HTTP方法,如果有必要的话可以用它的方法名。下面改写我们的方法,使它可以依靠方法名进行匹配。

分类:  spring
相关文章
|
3天前
|
Java 开发者 Spring
深入理解Spring Boot的@ComponentScan注解
【4月更文挑战第22天】在构建 Spring Boot 应用时,@ComponentScan 是一个不可或缺的工具,它使得组件发现变得自动化和高效。这篇博客将详细介绍 @ComponentScan 的基本概念、关键属性及其在实际开发中的应用。
20 4
|
5天前
|
Java 开发者 Spring
Spring Framework 中的 @Autowired 注解:概念与使用方法
【4月更文挑战第20天】在Spring Framework中,@Autowired 注解是实现依赖注入(Dependency Injection, DI)的一种非常强大的工具。通过使用 @Autowired,开发者可以减少代码中的引用绑定,提高模块间的解耦能力
28 6
|
1月前
|
XML Java 数据库连接
spring boot 参数的过滤注解与实战
在Spring Boot应用中,对于入参的过滤,通常会涉及到对Web层的数据验证和处理。Spring Boot借助Spring框架提供了强大的验证框架支持,主要基于JSR-303/JSR-380(Bean Validation API)规范,以及Spring自身的@Valid或@Validated注解来实现请求参数的验证。以下是一些常见的使用案例来展示如何对参数进行过滤和验证。
29 1
|
1月前
|
Java Spring 容器
【Java】Spring如何扫描自定义的注解?
【Java】Spring如何扫描自定义的注解?
35 0
|
1月前
|
Java 测试技术 数据库
SpringBoot:@Profile注解和Spring EL
SpringBoot:@Profile注解和Spring EL
|
1月前
|
Java API 开发者
Spring中@import注解终极揭秘
在Spring框架中,@Import注解可以用来引入一个或多个组件,这些组件通常是通过@Bean注解定义的,当使用@Import注解时,实际上是在告诉Spring:“除了当前配置类中的bean定义外,还想包含另一个配置类(或多个配置类)中定义的bean。”
Spring中@import注解终极揭秘
|
2月前
|
监控 Java 调度
Spring中的任务调度:探索@Scheduled和@Schedules注解的威力
Spring中的任务调度:探索@Scheduled和@Schedules注解的威力
37 0
|
1月前
|
存储 缓存 Java
【Spring原理高级进阶】有Redis为啥不用?深入剖析 Spring Cache:缓存的工作原理、缓存注解的使用方法与最佳实践
【Spring原理高级进阶】有Redis为啥不用?深入剖析 Spring Cache:缓存的工作原理、缓存注解的使用方法与最佳实践
|
1月前
|
Java 数据库 Spring
【spring(四)】Spring事务管理和@Transactional注解
【spring(四)】Spring事务管理和@Transactional注解
|
1月前
|
Java Spring 容器
Spring中@Autowired和@Resource注解异同点
Spring中@Autowired和@Resource注解异同点
31 0