博主信息
博文 15
粉丝 0
评论 0
访问量 27737
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
SpringBoot常见get/post请求参数处理、参数注解校验及参数自定义注解校验详解
P粉622841118
原创
2843人浏览过

目录
springboot常见httpget,post请求参数处理
PathVaribale获取url路径的数据
RequestParam获取请求参数的值
注意
GET参数校验
POSTJSON参数校验
自定义注解校验
总结

spring boot 常见http get ,post请求参数处理
在定义一个Rest接口时通常会利用GET、POST、PUT、DELETE来实现数据的增删改查;这几种方式有的需要传递参数,后台开发人员必须对接收到的参数进行参数验证来确保程序的健壮性

GET
一般用于查询数据,采用明文进行传输,一般用来获取一些无关用户信息的数据
POST
一般用于插入数据
PUT
一般用于数据更新
DELETE
一般用于数据删除
一般都是进行逻辑删除(即:仅仅改变记录的状态,而并非真正的删除数据)
@PathVaribale 获取url中的数据

@RequestParam 获取请求参数的值

@GetMapping 组合注解,是 @RequestMapping(method = RequestMethod.GET) 的缩写

@RequestBody 利用一个对象去获取前端传过来的数据

PathVaribale 获取url路径的数据
请求URL:

localhost:8080/hello/id 获取id值

实现代码如下:
@RestController public class HelloController { @RequestMapping(value="/hello/{id}/{name}",method= RequestMethod.GET) public String sayHello(@PathVariable("id") Integer id,@PathVariable("name") String name){ return "id:"+id+" name:"+name; } }
输出:

id:81name:hello

RequestParam 获取请求参数的值
获取url参数值,默认方式,需要方法参数名称和url参数保持一致

localhost:8080/hello?id=1000
@RestController public class HelloController { @RequestMapping(value="/hello",method= RequestMethod.GET) public String sayHello(@RequestParam Integer id){ return "id:"+id; } }
输出:

id:100

url中有多个参数时,如:

localhost:8080/hello?id=98&&name=helloworld

具体代码如下:
@RestController public class HelloController { @RequestMapping(value="/hello",method= RequestMethod.GET) public String sayHello(@RequestParam Integer id,@RequestParam String name){ return "id:"+id+ " name:"+name; } }
获取url参数值,执行参数名称方式

localhost:8080/hello?userId=1000
@RestController public class HelloController { @RequestMapping(value="/hello",method= RequestMethod.GET) public String sayHello(@RequestParam("userId") Integer id){ return "id:"+id; } }
输出:

id:100

注意
不输入id的具体值,此时返回的结果为null。具体测试结果如下:

id:null

不输入id参数,则会报如下错误:

whitelable Error Page错误

Java技术迷

GET参数校验
用法:不输入id时,使用默认值

具体代码如下:

localhost:8080/hello
@RestController public class HelloController { @RequestMapping(value="/hello",method= RequestMethod.GET) //required=false 表示url中可以无id参数,此时就使用默认参数 public String sayHello(@RequestParam(value="id",required = false,defaultValue = "1") Integer id){ return "id:"+id; } }
输出

id:1

POST JSON参数校验
常用校验注解

注意:

接收到的参数默认都是字符串类型的

有的注解只能用在String类型的属性上

@JsonProperty可以实现前端的属性名和后台实体类的属性名不一致问题

校验方式:

使用@RequestBody @Valid 对JSON参数进行获取和校验。

通过BindingResult bindingResult 去获取校验结果。

BindingResult 源码:

技巧01:利用BindingResult对象的hasErrors方法判断是否有参数错误

技巧02:利用BindingResult对象的getFieldErrors方法获取所有有参数错误的属性

技巧03:利用错误属性对象的getDefaultMessage去获取错误提示信息
`@RequestMapping(value = “/demo5”,produces = MediaType.TEXT_PLAIN_VALUE)
@ResponseBody
public String test5(@RequestBody @Valid User user , BindingResult bindingResult){
if(bindingResult.hasErrors()){
List<ObjectError> objectErrors = bindingResult.getAllErrors();
System.out.println(objectErrors.toString());
for(ObjectError objectError: objectErrors){
System.out.println(“objectError = “ + objectError.getObjectName());
System.out.println(“objectError = “ + objectError.getDefaultMessage());
System.out.println(“objectError = “ + objectError.getCode());
System.out.println(“objectError = “ + objectError.getArguments());

  1. }
  2. }
  3. String str = user.toString();
  4. return str;
  5. }`

对应User实体类代码:
`public class User {
@NotEmpty(message = “ID不能为空”)
@NotBlank(message = “ID不能为空哟”)
private String id;

  1. @Min(value = 18)
  2. @Max(value = 30)
  3. private Integer age;
  4. @NotEmpty(message = "昵称不能为空")
  5. @NotBlank(message = "昵称不能为空哟")
  6. @JsonProperty("nickname") // 当前端属性为nick后台接收对象的属性为nickName时可以用@JsonProperty来保持一致
  7. private String name;
  8. ....省略get set方法`

自定义注解校验
1、定义一个校验注解

代码如下
`import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.PARAMETER, ElementType.FIELD})
@Constraint(validatedBy = MyFormValidatorClass.class)
public @interface MyFormValidator {
String value();
String message() default “name can be test”;
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}2、定义一个约束校验import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.lang.annotation.Annotation;

public class MyFormValidatorClass implements ConstraintValidator<MyFormValidator, Object>, Annotation {
private String values;

  1. @Override
  2. public void initialize(MyFormValidator myFormValidator) {
  3. this.values = myFormValidator.value();
  4. }
  5. @Override
  6. public boolean isValid(Object value, ConstraintValidatorContext context) {
  7. if("test".equals((String)value)){
  8. return true;
  9. }
  10. return false;
  11. }
  12. @Override
  13. public Class<? extends Annotation> annotationType() {
  14. return null;
  15. }

}3、实体类中使用public class User2 {
@NotEmpty(message = “ID不能为空”)
@NotBlank(message = “ID不能为空哟”)
//自定义校验注解-校验id是否为test
@MyFormValidator(value = “abc”,message = “dd”)
private String id;

  1. @Min(value = 18)
  2. @Max(value = 30)
  3. private Integer age;
  4. @NotEmpty(message = "昵称不能为空")
  5. @NotBlank(message = "昵称不能为空哟")
  6. @JsonProperty("nickname") // 当前端属性为nick后台接收对象的属性为nickName时可以用@JsonProperty来保持一致

4、测试代码:@RequestMapping(value = “/demo6”,produces = MediaType.TEXT_PLAIN_VALUE)
@ResponseBody
public String test6(@RequestBody @Valid User2 user , BindingResult bindingResult){
if(bindingResult.hasErrors()){
List<ObjectError> objectErrors = bindingResult.getAllErrors();
System.out.println(objectErrors.toString());
for(ObjectError objectError: objectErrors){
System.out.println(“objectError = “ + objectError.getObjectName());
System.out.println(“objectError = “ + objectError.getDefaultMessage());
System.out.println(“objectError = “ + objectError.getCode());
System.out.println(“objectError = “ + objectError.getArguments());

  1. }
  2. }
  3. String str = user.toString();
  4. return str;
  5. }`

当请求参数ID不为test,objectErrors 中有该报错。

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学