注解postconstruct_webservice注解详解

注解postconstruct_webservice注解详解之前很多注解老是不太清楚作用并且容易搞混,这次一次性搞明白!这是最近在使用postman做接口测试的时候发现自己的这个知识盲点

注解postconstruct_webservice注解详解"

  之前很多注解老是不太清楚作用并且容易搞混,这次一次性搞明白!

  这是最近在使用postman做接口测试的时候发现自己的这个知识盲点。我们通常使用postman做测试的时候最常用的就是post与get请求,两者的区别主要在于一个将参数放在url中进行传递一个将参数放在request body中进行传递这里我们不做过多陈述。直接上干货!

  RequestBody注解的主要作用就是用于接收前端的参数,当我们使用post请求的时候,我们会将参数放在request body中,此时我们就需要在Controller的方法的参数前面加上@RequestBody用来接受到前端传过来的request body中的值,举个栗子:

@Controller
@RequestMapping(“/test”)
public class test{

public void testMethod(@RequestBody String string)"{

       System.out.println("测试");
  
  }
}

写法很简单就是这样,直接在参数前面加一个注解就可以了,接下来我们详细介绍一下使用过程中需要注意的问题:

首先当我们使用@RequestBody接收数据的时候,前端的请求方法要使用post方式来进行提交;

第二、一个请求只能有一个RequestBody,也就是说,当一个方法中有两个参数的时候,最多只能有一个参数加@RequestBody注解用来接受request body中的参数;

第三、@RequestBody接受的参数是来自request body中也就是请求体。一般用于处理非Content-Type:application/x-www-form-urlencoded编码格式的数据。比如application/json、application/xml等。

  说到RequestBody就不得不说到RequestParam,首先介绍一下RequestParam的使用场景:

@RequestParam接收的参数主要是来自request Header中,即请求头中。通常用于get请求中,我们都知道get请求的参数都是写在url中的,例如:http://localhost:8080/my/api/testMethod?name=雷神&age=3   该url我们可以看到有那么和age两种属性,那么当我们将此请求发送到后台服务以后,Controller写法如下:

@Controller
@RequesMapping(“/api”)
public class test{

public void testMethod(@RequestParam(value="name",required=false,defaultValue="雷神")String name,@RequestParam(value="age")Int age){

    System.out.println("年仅"+age+“岁肥宅”+name);

}

}

  testMethod方法中的参数一共有两个,一个是name,一个是age。与RequestBody不同的是,如果你在参数前面加了@RequestParam注解那么该参数则请求中则必须有对应的参数名(不管其是否有值),否则的话请求会报错(应该是报400)!如果不加@RequestParam注解的话,当你的请求中有对应的参数名的时候会自动匹配到值,如果没有对应的参数的话请求特可以也可以正常发送。

  现在解释一下@RequestParam的括号中的三个参数的意思,value值得就是请求的url中必须要有的参数名,相当于key值;required表示的是是否为必须,也就是说参数在url中是否为必须,默认的是true;defaultValue指的则是参数的默认值;

  还有一点需要解释一下,如果你直接在参数前面加上@RequestParam,那么该参数的名字就是url中必须要有的参数名

  总结一下,RequestParam接收的参数是来自requestHeader中,即请求头,通常用于get请求。RequestBody注解接收的参数是来自requestBody中的,即请求体;一般用于处理非Content-Type:application/x-www-form-urlencoded编码格式的数据,比如application/json、application/xml等类型的数据;

 

今天的文章注解postconstruct_webservice注解详解分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/78675.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注