1 spring注解介绍
Spring Framework是一个开源的Java平台,广泛用于创建高性能的企业应用程序。随着Spring的发展,注解(Annotation)已经成为了配置Spring应用程序的主要方式,逐渐取代了传统的XML配置。使用注解可以使代码更加简洁明了,提高开发效率和可读性。
Spring的注解驱动的编程模型大大简化了Java企业应用的开发。通过减少配置的复杂性,提高代码的清晰度和模块化,Spring注解使得开发者可以更加专注于业务逻辑的实现。随着Spring框架的不断演进,注解的使用变得越来越灵活和强大,为构建现代Java应用程序提供了强有力的支持。
1.1 核心注解
1.1.1 @SpringBootApplication
这是一个组合注解,标记在应用的主类上。它结合了以下三个注解的功能:
@Configuration:标记一个类作为bean定义的源。
@EnableAutoConfiguration:启用Spring Boot的自动配置机制。
@ComponentScan:启用@Component注解的扫描。
1.1.2 @Component
这是一个泛化的注解,用于定义Spring管理的组件。它表明一个类会作为组件类,并告诉Spring要为这个类创建bean。
1.1.3 @Repository
在DAO层(数据访问层)使用,标记一个类作为数据访问对象。
1.1.4 @Service
在服务层使用,标记一个类作为服务类。
1.1.5 @Controller
在表现层使用,标记一个类作为Spring MVC控制器。
1.1.6 @RestController
结合了@Controller和@ResponseBody的功能,用于创建RESTful Web服务。
1.1.7 @RequestMapping & @GetMapping/@PostMapping/@PutMapping/@DeleteMapping
这些注解用于处理Web请求。@RequestMapping是一个通用的请求处理注解,而其他注解是它的特化版本,用于处理HTTP中的GET、POST、PUT和DELETE请求。
1.1.8 @Autowired
用于自动注入Spring容器中的bean。可以用于变量、方法和构造函数上。
1.1.9 @Qualifier
与@Autowired一起使用,当有多个同类型的bean时,用于指定要注入的bean。
1.1.10 @Bean
在方法上使用,表明这个方法将返回一个对象,该对象要注册为Spring应用程序上下文中的bean。
1.2 配置和管理
1.2.1 Java配置类
使用注解配置时,通常会有一个或多个带有@Configuration注解的Java类,它们定义了应用程序上下文中的bean。
1.2.2 依赖注入
@Autowired注解用于实现依赖注入。Spring容器会在创建bean时自动注入所需的依赖。
1.2.3 条件化的Bean创建
可以使用@Conditional注解(或其特化形式如@ConditionalOnClass、@ConditionalOnBean)来根据特定条件创建beans。
1.3 AOP和事务管理
1.3.1 @Aspect
在类上使用,将其标记为切面类。
1.3.2 @Before、@After、@Around
这些注解用于定义通知(Advice),是AOP(面向切面编程)的关键部分。
1.3.3 @Transactional
声明事务的范围和行为。可以用于类或方法级别。
1.4 测试支持
1.4.1 @SpringBootTest
用于Spring Boot应用程序的集成测试,可以启动一个嵌入式的Spring应用程序上下文。
1.4.2 @DataJpaTest、@WebMvcTest等
用于更细粒度的测试配置,专门测试JPA仓库、Spring MVC控制器等。
1.4.3 @MockBean 和 @SpyBean
用于在Spring Boot测试中添加和配置mock对象。
1.5 实用注解
1.5.1 @Value
用于注入属性文件中的值。
1.5.2 @Profile
指定某个bean只在特定的配置文件激活时才创建。
1.5.3 @PropertySource
指定用于填充环境属性的属性文件。
1.5.3 @Scope
定义bean的作用域,如singleton、prototype等。
2 Spring注解详解
2.1 bean factory注解
@Configuration
把一个类作为一个IoC容器,可理解为用xml里的
@ComponentScan
启用类扫描,与xml中
@Conditional
根据满足某个特定的条件创建一个特定的Bean
@Bean
告诉被注释的方法产生一个Bean,然后交给Spring容器,用在方法上,告诉Spring容器可以从这个方法中拿到一个Bean
@Lazy
用于指定该Bean是否取消预初始化。主要用于修饰Spring Bean类,用于指定该Bean的预初始化行为
@DependsOn
用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean
@Import
支持导入配置类,也支持导入普通的java类,并将其声明成一个bean
@ImportResource、@Value
用来进行资源文件的读取
@Primary
在众多相同的bean中,优先使用用@Primary注解的bean
@Qualifier
指定某个bean有没有资格进行注入
@Profile
标注的组件只有当指定profile值匹配时才生效,可以通过以下方式设置profile值:
(1)设置spring.profiles.active属性(通过JVM参数、环境变量或者web.xml中的Servlet context参数)
(2)ApplicationContext.getEnvironment().setActiveProfiles(“ProfileName”)根据实际环境设置profile值,然后被profile标注(而且value=设置值)的bean才会被注册到spring容器
@Scope
默认是单例模式,即scope="singleton"
singleton单例模式:全局有且仅有一个实例
prototype原型模式:每次获取Bean的时候会有一个新的实例
request:equest表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP request内有效
session:session作用域表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前
HTTP session内有效
global session:作用域类似于标准的HTTP Session作用域,仅仅在基于portlet的web应用中才有意义。
@PropertySource
读取properties文件
@Autowired
它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。 通过 @Autowired的使用来消除set ,get方法
@Required
适用于bean属性的setter方法并且它指示,受影响的bean属性必须在配置时被填充在XML配置文件中,否则容器将抛出BeanInitializationException例外
@Order
在spring 4.0之前,@Order标记只支持AspectJ的切面排序。spring 4.0对@Order做了增强,它开始支持对装载在诸如Lists和Arrays容器中的自动包装(auto-wired)组件的排序
@AliasFor
给注解的属性起别名,让使用注解时,更加的容易理解
@Component
这是一个元注解,意思是它可以用于标注其他注解,被它标注的注解和它起到相同或者类似的作用
2.2 Spring mvc注解
@Controller
用于标注控制层组件
@Service
用于标注业务层组件
@Respository
用于标注数据层组件DAO
@ControllerAdvice
通过@ControllerAdvice。我们可以将对于控制器的全局配置放置在同一个位置,注解
了@ControllerAdvice的类的方法可以使用@ExceptionHandler,@InitBinder,@ModelAttribute注解到方法上,这对所有注解了@RequestMapping的控制器内的方法有效。
@ExceptionHandler:
用于全局处理控制器里面的异常。
@InitBinder:
用来设置WebDataBinder,WebDataBinder用来自动绑定前台请求参数到Model中。
@ModelAttribute
本来的作用是绑定键值对到Model里,此处是让全局的@RequestMapping都能获得在此处设置的键值对。
@InitBinder
用于在@Controller中标注于方法,表示为当前控制器注册一个属性编辑器或者其他,只对当前的Controller有效
@ModelAttribute
两种应用场景:运用在参数上,会将客户端传递过来的参数按名称注入到指定对象中,并且会将这个对象自动加入ModelMap中,便于View层使用;运用在方法上,会在每一个@RequestMapping标注的方法前执行,如果有返回值,则自动将该返回值加入到ModelMap中;
@MatrixVariable
在传递path相关的参数是使用,利用MatrixVariable可以动态传递参照的元素id
@RequestMapping
用来处理请求地址映射,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径
@RequestParam
用来处理请求参数映射 @RequestPart 用来处理文件上传 @RequestBody 对应的POST请求的body,body即是获取的参数,如果想通过参数去获取,则要使用@RequestParams
@RequestHeader
用于映射控制器参数以请求头值的注释
@RequestAttribute
用于访问由过滤器或拦截器创建的、预先存在的请求属性
@SessionAttribute
用于访问预先存在的全局会话属性 @CookieValue用来获取Cookie中的值
@ExceptionHandler
对web的服务器端运行错误, 做统一的处理
@CrossOrigin
跨域注解
@GetMapping
简化常用的HTTP方法的映射,是@RequestMapping(method = RequestMethod.GET)的缩写
@PostMapping
组合注解,简化常用的HTTP方法的映射
@PutMapping
组合注解,简化常用的HTTP方法的映射
@DeleteMapping
组合注解,简化常用的HTTP方法的映射
@PatchMapping
组合注解,简化常用的HTTP方法的映射
@RestController
标识类作为控制器,每一个方法返回域对象pojo代替一个视图
@RestControllerAdvice
一个组件注解,异常统一处理
@ResponseBody
内容或对象作为 HTTP 响应正文返回,并调用适合HttpMessageConverter的Adapter转换对象,写入输出流@ResponseStatus 用于修饰一个类或者一个方法,修饰一个类的时候,一般修饰的是一个异常类@PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中
@Validated
是@Valid 的一次封装,是Spring提供的校验机制使用
@EnableWebMvc
启用spring mvc
JSR-250
@PostConstruct
注解的方法将会在依赖注入完成后被自动调用,顺序Constructor >> @Autowired >> @PostConstruct
@PreDestroy
销毁之前调用方法@Resource 注解被用来激活一个命名资源(named resource)的依赖注入
JSR-330
@Inject
可以注入对象,在属性域上面注入、在set方法或者其他需要注入的方法上面注入、在构造器上面注入@Inject没有@required标签,强制要求对象不能为空
@Named
可以有值,如果没有值生成的Bean名称默认和类名相同
@Max
校验最大值
@Min
校验最小值
@NotNull
校验不能为空
@Size
校验长度
@Pattern
正则校验
@Valid
标识校验bean,要紧挨着JavaBean,要不然不会生效的
2.3 数据处理层注解
@EnableTransactionManagement
激活事务管理@Transactional 可以作用于接口、接口方法、类以及类方法上。当作用于类
上时,该类的所有 public 方法将都具有该类型的事务属性,同时,我们也可以在方法级别
使用该标注来覆盖类级别的定义
@EnableAspectJAutoProxy
激活Aspect自动代理
@EnableCaching
激活数据缓存
@CacheConfig
在类级别上统一定义缓存名称
@Cacheable
主要针对方法配置,能够根据方法的请求参数对其结果进行缓存
@Caching
对于@Caching注解来讲,如果有两种不同的需求,都是放在同一个方法上,这种需求如果
只是使用@CacheEvict或者@CachePut是无法实现,因为他们不能多样化的作用在同一个
方法上。可以使用@Caching(evict={@CacheEvict(“a1”),@CacheEvict(“a2”,allEntries=true)})
@CachePut
主要针对方法配置,能够根据方法的请求传输对其结果进行缓存,和@Cacheable不同的
是,它每次都会触发真实的方法调用
@CacheEvict
主要针对方法配置,能够根据一定的条件对缓存进行清空
Bean Validation 中内置的 constraint
@Null 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max=, min=) 被注释的元素的大小必须在指定的范围内
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
Hibernate Validator 附加的 constraint
@NotBlank(message =) 验证字符串非null,且长度必须大于0
@Email 被注释的元素必须是电子邮箱地址
@Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range(min=,max=,message=) 被注释的元素必须在合适的范围内
MyBatis
@Param 映射参数注解@Select 查询注解@Update 更新注解@Delete 删除注解@Insert 插入注解@Results 结果注解@Result 结果注解@Options 选项注解
2.4 切面注解@Aspect 声明一个切面
@After 注解切入时机为执行完成
@AfterReturning 注解切入时机为执行返回
@AfterThrowing 注解切入时机为抛出异常
@Around 注解切入时机为环绕
@Before 注解切入时机为开始调用
@DeclareParents 注解引入新的方法
@Pointcut 定义切点
2.5 任务处理注解
@EnableAsync 开启多线程,可以标注在方法、类上
@Async 异步方法;这些方法将在执行的时候,将会在独立的线程中被执行,调用者无需等待它的完成,即可继续其他的操作
@EnableScheduling 开启对计划任务的支持,然后在要执行计划任务的方法上注解@Scheduled,声明这是一个计划任务
@Scheduled 声明这是一个计划任务
@Schedules