JavaWeb 的常用的请求传参注解

1、@RequestMapping

@RequestMapping 既可以用在类级别,也可以用在方法级别,当它定义在类级别的时候,标明该控制器所处理的请求都将被映射到这个路径下。另外,@RequestMapping中可以使用method属性,如果指定了method属性的值,那么就只能使用指定的请求方法,如果没有指定的话,那么就可以使用HTTP的get/post方法了。

1、get 请求特点:

a. 请求参数会添加到请求资源路径的后面,只能添加少量参数(因为请求行只有一行,大约只能存放2K左右的数据)
b. 请求参数会显示在浏览器地址栏,路由器会记录请求地址 (极为的不安全)
c.如果传输中文,必定会乱码(原因:get 请求默认编码格式为:IIO-8859-1,后台编码格式一般为:GBK或者UTF-8)

2、post 请求的特点:

a. 请求参数添加到请求体里面,可以添加大量的参数(也解释了为什么浏览器地址栏不能发送post请求,在地址栏里我们只能填写URL,并不能进入到 Http 包的请求体当中)
b. 相对安全,但是,post 请求不会对请求参数进行加密处理(可以使用https协议来保证数据安全)

2、@GetMapping

用于将HTTP GET请求映射到特定处理程序方法的注释。相当于@RequestMapping(method = RequestMethod.GET)

3、@PostMapping

用于将 HTTP POST 请求映射到特定处理程序方法的注释。相当于@RequestMapping(method = RequestMethod.POST)

4、@RequestParam

这个注解是使用在方法的形参上的,主要用途就是将请求的参数绑定到方法的形参上,有一个required属性,默认情况下是true,就是必须要传参数,如果想该形参可传可不传参数的话,就将属性值设置为false即可。

@RequestMapping("/hello")
  public String hello(@RequestParam(value = "name", required = false) String name, @RequestParam(value = "age", required = true) String age) {
    
    
  //age参数必须传 ,name可传可不传
  ...
  }

5、@PathVariable

该注解主要是用于做动态绑定使用,让形参的值变成可供使用的URL变量,多用在 Restful 风格中。

@RequestMapping(value="/hello/{name}",method=RequestMethod.GET)
public String findPet(@PathVariable String name) {
    
    
//使用@PathVariable注解绑定 {name} 到String name
}

@PathVariable中的参数可以是任意的简单类型,如int、long、Date等,Spring会自动将其转换成合适的类型或者抛出TypeMismatchException异常,也可以注册支持额外的数据类型。另外,它也支持正则表达式,这就决定了它超强的属性,它能在路径模板中使用占位符,可以设定特定的前缀匹配和后缀匹配,自定义格式等。

6、@RequestBody

该注解是指方法形参应该被绑定到HTTP请求的Body上。

@RequestMapping(value = "/something", method = RequestMethod.PUT)
public void handle(@RequestBody User user){
    
    
   //可以绑定自定义的对象类型
}

在这里插入图片描述
(1)使用 @RequestBody 注解

@RequestBody 注解是用于接收请求的 Content-Type为application/json 类型的请求,数据类型是 JSON
在这里插入图片描述

(2)不使用 @RequestBody 注解

不使用 @RequestBody 注解时,可以接收 Content-Type为application/x-www-form-urlencoded 类型,或者 Text 类型的请求所提交的数据,数据格式:

aaa=111&bbb=222  

form 表单提交以及用 Ajax 提交数据时方法所发送的请求就是这种类型
后台只需用具有对应属性 id 和 name 的对象接收就行
在这里插入图片描述
如果使用了 @RequestBody 来强行接收 Text 或者 application/x-www-form-urlencoded 类型,会报类型 not supported 的如下错误:
在这里插入图片描述

おすすめ

転載: blog.csdn.net/IT__learning/article/details/121582492