1:常用注解
@RestController
只返回对象,对象数据直接以 JSON 或 XML 形式写入 HTTP 响应(Response)中
@RequestParam
如果不使用@RequestParam,要求request传入参数名称和controller方法的形参名称一致,方可绑定成功。
如果使用@RequestParam,不用限制request传入参数名称和controller方法的形参名称一致。
通过required属性指定参数是否必须要传入,如果设置为true,没有传入参数,会报错。
直接参数绑定
直接在controller方法形参上定义下边类型的对象,就可以使用这些对象。在参数绑定过程中,如果遇到下边类型直接进
行绑定。
1). HttpServletRequest:通过request对象获取请求信息
2). HttpServletResponse:通过response处理响应信息
3). HttpSession:通过session对象得到session中存放的对象
4). Model/ModelMap:model是一个接口,modelMap是一个接口实现 。作用:将model数据填充到request域。
2:参数校验
@Email(message="邮箱格式错误")
private String email;
@NotNull(message="名字不能为空")
private String userName;
@Max(value=120,message="年龄最大不能查过120")
private int age;
@NotNull(message = "传入的姓名为null,请传值")
@NotEmpty(message = "传入的姓名为空字符串,请传值")
private String name; // 姓名
@NotNull(message = "传入的分数为null,请传值")
@Min(value = 0,message = "传入的学生成绩有误,分数应该在0~100之间")
@Max(value = 100,message = "传入的学生成绩有误,分数应该在0~100之间")
private Integer score; // 分数
@NotNull(message = "传入的电话为null,请传值")
@NotEmpty(message = "传入的电话为空字符串,请传值")
@Length(min = 11, max = 11, message = "传入的电话号码长度有误,必须为11位")
private String mobile; // 电话号码
@NotNull
@Length(min = 2, max = 10)
private String userName;
@NotNull
@Length(min = 6, max = 20)
private String account;
@NotNull
@Length(min = 6, max = 20)
private String password;
@Pattern(regexp = "((^Man$|^Woman$|^UGM$))", message = "sex 值不在可选范围")
@NotNull(message = "sex 不能为空")
private String sex;
空检查
@Null 验证对象是否为null
@NotNull 验证对象是否不为null, 无法查检长度为0的字符串
@NotBlank 检查约束字符串是不是Null还有被Trim的长度是否大于0,只对字符串,且会去掉前后空格.
@NotEmpty 检查约束元素是否为NULL或者是EMPTY.
Booelan检查
@AssertTrue 验证 Boolean 对象是否为 true
@AssertFalse 验证 Boolean 对象是否为 false
长度检查
@Size(min=, max=) 验证对象(Array,Collection,Map,String)长度是否在给定的范围之内
@Length(min=, max=) string is between min and max included.
日期检查
@Past 验证 Date 和 Calendar 对象是否在当前时间之前
@Future 验证 Date 和 Calendar 对象是否在当前时间之后
@Pattern 验证 String 对象是否符合正则表达式的规则
@Null
被注释的元素必须为 null
•
@NotNull
被注释的元素必须不为 null
•
@AssertTrue
被注释的元素必须为 true
•
@AssertFalse
被注释的元素必须为 false
•
@Min(value)
被注释的元素必须是一个数字,其值必须大于等于指定的最小值
•
@Max(value)
被注释的元素必须是一个数字,其值必须小于等于指定的最大值
•
@DecimalMin(value)
被注释的元素必须是一个数字,其值必须大于等于指定的最小值
•
@DecimalMax(value)
被注释的元素必须是一个数字,其值必须小于等于指定的最大值
•
正则表达式说明:
- ^string : 匹配以 string 开头的字符串
- string$ :匹配以 string 结尾的字符串
- ^string$ :精确匹配 string 字符串
- ((^Man$|^Woman$|^UGM$)) : 值只能在 Man,Woman,UGM 这三个值中选择
@Size(max=, min=)
被注释的元素的大小必须在指定的范围内
•
@Digits (integer, fraction)
被注释的元素必须是一个数字,其值必须在可接受的范围内
•
@Past
被注释的元素必须是一个过去的日期
•
@Future
被注释的元素必须是一个将来的日期
•
@Pattern(regex=,flag=)
被注释的元素必须符合指定的正则表达式
@NotBlank(message =)
验证字符串非null,且长度必须大于0
•
@Email
被注释的元素必须是电子邮箱地址
•
@Length(min=,max=)
被注释的字符串的大小必须在指定的范围内
•
@NotEmpty
被注释的字符串的必须非空
•
@Range(min=,max=,message=)
被注释的元素必须在合适的范围内
@NotNull(message = "传入的姓名为null,请传值")
@NotEmpty(message = "传入的姓名为空字符串,请传值")
@Min(value = 0,message = "传入的学生成绩有误,分数应该在0~100之间")
@Max(value = 100,message = "传入的学生成绩有误,分数应该在0~100之间")
@Length(min = 11, max = 11, message = "传入的电话号码长度有误,必须为11位")
@Email(message = "email 格式不正确")
@Pattern(regexp = "((Man$|Woman$|^UGM$))", message = "sex 值不在可选范围")
@NotBlank(message = "name 不能为空",groups = Update.class)
3 SpringBoot配置途径优先级
1. 命令行参数
2. java:comp/env里的JNDI属性
3. JVM系统属性
4. 操作系统环境变量
5. 随机生成的带random.*前缀的属性(在设置其他属性时,可以引用它们,比如${random. long})
6. 应用程序以外的application.properties或者appliaction.yml文件
7. 打包在应用程序内的application.properties或者appliaction.yml文件
8. 通过@PropertySource标注的属性源
9. 默认属性