前言
传统的Spring做法是使用.xml
文件来对bean进行注入或者是配置aop、事物,这么做有两个缺点:
- 如果所有的内容都配置在
.xml
文件中,那么.xml
文件将会十分庞大;如果按需求分开.xml
文件,那么.xml
文件又会非常多。总之这将导致配置文件的可读性与可维护性变得很低。 - 在开发中在
.java
文件和.xml
文件之间不断切换,是一件麻烦的事,同时这种思维上的不连贯也会降低开发的效率。
为了解决这两个问题,Spring引入了注解,通过@XXX
的方式,让注解与Java Bean
紧密结合,既大大减少了配置文件的体积,又增加了Java Bean
的可读性与内聚性。
1
@SpringBootApplication
这个注解是SpringBoot项目的基石,创建SpringBoot项目之后会默认在主类加上。
@SpringBootApplication
可以把@SpringBootApplication看作是@Configuration、@EnableAutoConfiguration、@ComponentScan注解的集合。
根据SpringBoot官网,这三个注解的作用分别是:
@EnableAutoConfiguration:启用SpringBoot的自动配置机制。
@ComponentScan:扫描被@Component(@Service,@Controller)注解的bean,注解默认会扫描该类所在的包下所有的类。
@Configuration:允许在Spring上下文中注册额外的bean或导入其他配置类。
2
Spring Bean相关
@Autowired
自动导入对象到类中,自动装配,其作用是为了消除代码里的getter/setter与bean属性中的property。
private UserService userService;
@Component,@Repository,@Service,@Controller
我们一般使用@Autowired注解让Spring容器帮我们自动装配bean。要想把类标识成可用于@Autowired注解自动装配的bean的类,可以采用改一下注解实现:
@Component
:通用的注解,可标注任意类为Spring
组件。如果一个 Bean 不知道属于哪个层,可以使用@Component
注解标注。@Repository
: 对应持久层即 Dao 层,主要用于数据库相关操作。@Service
: 对应服务层,主要涉及一些复杂的逻辑,需要用到 Dao 层。@Controller
: 对应 Spring MVC 控制层,主要用户接受用户请求并调用 Service 层返回数据给前端页面。
@RestController
现在都是前后端分离,一般都不用@Controller注解,而是使用@RestController注解。
@RestController
注解是@Controller和
@ResponseBody
的合集,表示这是个控制器 bean,并且是将函数的返回值直 接填入 HTTP 响应体中,是 REST 风格的控制器。
@Scope
用在类上,声明Spring Bean的作用域,使用方法:
@Bean
- singleton : 唯一 bean 实例,Spring 中的 bean 默认都是单例的。
- prototype : 每次请求都会创建一个新的 bean 实例。
- request : 每一次 HTTP 请求都会产生一个新的 bean,该 bean 仅在当前 HTTP request 内有效。
- session : 每一次 HTTP 请求都会产生一个新的 bean,该 bean 仅在当前 HTTP session 内有效。
@Configuration
一般用来声明配置类,可以使用@Component注解替代,不过使用@Configuration
注解声明配置类更加语义化。
@Configuration
3
处理常见的HTTP请求类型
5种常见的请求类型:
- GET :请求从服务器获取特定资源。例如:
GET /users
(获取所有学生) - POST :在服务器上创建一个新的资源。例如:
POST /users
(创建学生) - PUT :更新服务器上的资源(客户端提供更新后的整个资源)。例如:
PUT /users/12
(更新编号为 12 的学生) - DELETE :从服务器删除特定的资源。例如:
DELETE /users/12
(删除编号为 12 的学生) - PATCH :更新服务器上的资源(客户端提供更改的属性,可以看做作是部分更新),使用的比较少,这里就不举例子了。
GET请求
@GetMapping("users") 等价于@RequestMapping(value="/users",method=RequestMethod.GET)
@GetMapping(
POST请求
@PostMapping("users") 等价于@RequestMapping(value="/users",method=RequestMethod.POST)
@PostMapping(
PUT请求
@PutMapping("/users/{userId}") 等价于@RequestMapping(value="/users/{userId}",method=RequestMethod.PUT)
@PutMapping(
DELETE请求
@DeleteMapping("/users/{userId}")等价于@RequestMapping(value="/users/{userId}",method=RequestMethod.DELETE)
@DeleteMapping(
PATCH请求
一般实际项目中,我们都是PUT不够用才使用PATCH请求去更新数据。
@PatchMapping(
4
前后端传值
@PathVariable和@RequestParam
@PathVariable用于获取路径参数,@RequestParam用于获取查询参数。
@GetMapping(
例如:请求url是:/user/{12345}/teachers?type=web
那么我们服务获取到的数据为:userId=12345,type=web
@RequestBody
用于读取 Request 请求(可能是 POST,PUT,DELETE,GET 请求)的 body 部分并且Content-Type 为 application/json 格式的数据,接收到数据之后会自动将数据绑定到 Java 对象上去。系统会使用HttpMessageConverter
或者自定义的HttpMessageConverter
将请求的 body 中的 json 字符串转换为 java 对象。
需要注意的是:一个请求方法只可以有一个@RequestBody
,但是可以有多个@RequestParam
和@PathVariable
。如果你的方法必须要用两个 @RequestBody
来接受数据的话,大概率是你的数据库设计或者系统设计出问题了!
5
读取配置信息
@value(常用)
使用 @Value("${property}")
读取比较简单的配置信息:
@ConfigurationProperties(常用)
通过@ConfigurationProperties
读取配置信息并与 bean 绑定。
6
参数校验
一些常用的字段验证的注解
@NotEmpty
被注释的字符串的不能为 null 也不能为空@NotBlank
被注释的字符串非 null,并且必须包含一个非空白字符@Null
被注释的元素必须为 null@NotNull
被注释的元素必须不为 null@AssertTrue
被注释的元素必须为 true@AssertFalse
被注释的元素必须为 false@Pattern(regex=,flag=)
被注释的元素必须符合指定的正则表达式@Email
被注释的元素必须是 Email 格式。@Min(value)
被注释的元素必须是一个数字,其值必须大于等于指定的最小值@Max(value)
被注释的元素必须是一个数字,其值必须小于等于指定的最大值@DecimalMin(value)
被注释的元素必须是一个数字,其值必须大于等于指定的最小值@DecimalMax(value)
被注释的元素必须是一个数字,其值必须小于等于指定的最大值@Size(max=, min=)
被注释的元素的大小必须在指定的范围内@Digits (integer, fraction)
被注释的元素必须是一个数字,其值必须在可接受的范围内@Past
被注释的元素必须是一个过去的日期@Future
被注释的元素必须是一个将来的日期- ......
验证请求体(RequestBody)
@Data
我们在需要验证的参数上加上了@Valid
注解,如果验证失败,它将抛出MethodArgumentNotValidException
。
@RestController
验证请求参数(Path Variables 和 Request Parameters)
一定不要忘记在类上加上 Validated
注解了,这个参数可以告诉 Spring 去校验方法参数。
@RestController
7
事务 @Transactional
在要开启事务的方法上使用@Transactional
注解即可!
@Transactional(rollbackFor = Exception.class)
我们知道 Exception 分为运行时异常 RuntimeException 和非运行时异常。在@Transactional
注解中如果不配置rollbackFor
属性,那么事物只会在遇到RuntimeException
的时候才会回滚,加上rollbackFor=Exception.class
,可以让事物在遇到非运行时异常时也回滚。
@Transactional
注解一般用在可以作用在类
或者方法
、接口上。
- 作用于类:当把
@Transactional 注解放在类上时,表示所有该类的
public 方法都配置相同的事务属性信息。 - 作用于方法:当类配置了
@Transactional
,方法也配置了@Transactional
,方法的事务会覆盖类的事务配置信息。 - 作用于接口:不推荐这种使用方法,因为一旦标注在Interface上并且配置了Spring AOP 使用CGLib动态代理,将会导致
@Transactional
注解失效。
8
Josn数据处理
过滤json数据
@JsonIgnoreProperties作用在类上用于过滤掉特定字段不返回或者不解析。
//生成json时将userRoles属性过滤
@JsonIgnore
一般用于类的属性上,作用和上面的@JsonIgnoreProperties
一样。
public
格式化Json数据
@JsonFormat一般用来格式化json数据。
@JsonFormat(shape=JsonFormat.Shape.STRING, pattern=
9
JPA相关
格式化Json数据
@Entity
声明一个类对应一个数据库实体。
@Table
设置表名
@Id声明一个字段为主键
@Entity
设置字段类型
@Column
声明字段。
示例:
设置属性 userName 对应的数据库字段名为 user_name,长度为 32,非空
@Column(name =
设置字段类型并且加默认值,这个还是挺常用的。
"tinyint(1) default 1")
指定不持久化的特定字段
@Transient
:声明不需要与数据库映射的字段,在保存的时候不需要保存进数据库 。
如果我们想让secrect
这个字段不被持久化,可以使用 @Transient
关键字声明。
"USER")
除了 @Transient
关键字声明, 还可以采用下面几种方法:
static String secrect;
一般使用注解的方式比较多。
创建枚举类型的字段
可以使用枚举类型的字段,不过枚举字段要用@Enumerated
注解修饰。
public
@Entity
数据库里面对应存储的是 MAIL/FEMAIL。