经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Spring » 查看文章
springboot RESTful以及参数注解的使用方式
来源:jb51  时间:2021/10/19 15:31:50  对本文有异议

springboot RESTful及参数注解使用

RESTful

Spring的复杂性不是来自于它处理的对象,而是来自于自身,不断演进发展的Spring会带来时间维度上复杂性,比如SpringMVC以前版本的@RequestMapping,到了新版本被下面新注释替代,相当于增加的选项:

  1. @GetMapping
  2. @PostMapping
  3. @PutMapping
  4. @DeleteMapping
  5. @PatchMapping

说明

1、@GetMapping

@RequestMapping(method = RequestMethod.GET)的简写

作用:对应查询,表明是一个查询URL映射

2、@PostMapping

@RequestMapping(method = RequestMethod.POST)的简写

作用:对应增加,表明是一个增加URL映射

3、@PutMapping

@RequestMapping(method = RequestMethod.PUT)的简写

作用:对应更新,表明是一个更新URL映射

4、@DeleteMapping

@RequestMapping(method = RequestMethod.DELETE)的简写

作用:对应删除,表明是一个删除URL映射

5、@PatchMapping

Patch方式是对put方式的一种补充;

put方式是可以更新.但是更新的是整体.patch是对局部更新;

参数注解的使用

  1. @PathVariable
  2. @RequestParam
  3. @RequestBody
  4. @ModelAttribute

说明

1. @PathVariable

获取路径参数。即url/{id}这种形式

@PathVariable绑定URI模板变量值

@PathVariable是用来获得请求url中的动态参数的

@PathVariable用于将请求URL中的模板变量映射到功能处理方法的参数上。//配置url和方法的一个关系@RequestMapping(“item/{itemId}”)

2.@RequestParam

获取查询参数。即url?name=这种形式

@RequestParam注解主要有哪些参数:

  • value:参数名字,即入参的请求参数名字,如username表示请求的参数区中的名字为username的参数的值将传入;
  • required:是否必须,默认是true,表示请求中一定要有相应的参数,否则将报404错误码;
  • defaultValue:默认值,表示如果请求中没有同名参数时的默认值,例如:
  1. public List getItemTreeNode(@RequestParam(value=“id”,defaultValue=“0”)long parentId)

3.@RequestBody

@requestBody注解常用来处理content-type不是默认的application/x-www-form-urlcoded编码的内容,比如说:application/json或者是application/xml等。一般情况下来说常用其来处理application/json类型。

通过@requestBody可以将请求体中的JSON字符串绑定到相应的bean上,当然,也可以将其分别绑定到对应的字符串上。

4.@ModelAttribute

在使用RESTful风格时,使用get请求,又想使用对象接收参数,就可以使用这个注解

不光适用于get请求,同样也适用于put和delete请求

springboot Restful使用记录

创建项目

通过spring官网创建项目

https://start.spring.io/

在这里插入图片描述

  • 项目名称取为studyRest
  • 项目依赖WEB

Rest组件使用

使用@RestController标记类为提供Restful服务的Contoller

@GetMapping为资源定位一部分,也就是url,对应http://localhost:8080/test

  1. @RestController
  2. public class MyRestContoller1 {
  3. @GetMapping("/test")
  4. public Map<String, String> getData() {
  5. Map<String, String> data = new HashMap<String, String>();
  6. data.put("id", "111");
  7. data.put("name", "zhangsan");
  8. return data;
  9. }
  10. }

测试(这里使用浏览器测试,后续使用Postman工具)

在这里插入图片描述

@GetMapping关键字对应GET请求,也就是查询,请求还可以有参数,对应@PathVariable与@RequestParam注解

  1. @GetMapping("/test/{id}")
  2. public Map<String, String> getData2(@PathVariable String id, @RequestParam(required = false) String name) {
  3. Map<String, String> data = new HashMap<String, String>();
  4. data.put("id", id);
  5. data.put("name", name);
  6. return data;
  7. }

测试,返回值为入参传入参数

在这里插入图片描述

Post类型,新增操作

新增使用@PostMapping描述URL

新增一般都会带有大量数据,一般都是使用@RequestBody注解封装参数

  1. @PostMapping("/test2/add")
  2. public Map<String, String> addData(@RequestBody Map<String, String> data) {
  3. return data;
  4. }

测试

在这里插入图片描述

注意两点,不正确都会报错

  • 请求类型必须是POST
  • Content-type必须要设置为application/json,因为入参形式为JSON格式

在这里插入图片描述

更新与删除操作

使用上与Post一致,只是不同类型需要使用对应的主机

  • PUT:@PutMapping
  • DELETE:@DeleteMapping
  1. @PutMapping("/test2/update")
  2. public Map<String, String> updateData(@RequestBody Map<String, String> data) {
  3. return data;
  4. }
  5. @DeleteMapping("/test2/delete")
  6. public Map<String, String> deleteData(@RequestBody Map<String, String> data) {
  7. return data;
  8. }

RequestMapping使用

RequestMapping是一个通用注解,包含上述所有操作

  1. @RestController
  2. @RequestMapping(value = "/parent")
  3. public class RequestRestContoller {
  4. @RequestMapping(value = "/get", method = RequestMethod.GET)
  5. public Map<String, String> get() {
  6. Map<String, String> data = new HashMap<String, String>();
  7. data.put("id", "111");
  8. data.put("name", "zhangsan");
  9. return data;
  10. }
  11. @RequestMapping(value = "/add", method = RequestMethod.POST)
  12. public Map<String, String> add() {
  13. Map<String, String> data = new HashMap<String, String>();
  14. data.put("id", "111");
  15. data.put("name", "zhangsan");
  16. return data;
  17. }
  18. @RequestMapping(value = "/update", method = RequestMethod.PUT)
  19. public Map<String, String> update() {
  20. Map<String, String> data = new HashMap<String, String>();
  21. data.put("id", "111");
  22. data.put("name", "zhangsan");
  23. return data;
  24. }
  25. @RequestMapping(value = "/delete", method = RequestMethod.DELETE)
  26. public Map<String, String> delete() {
  27. Map<String, String> data = new HashMap<String, String>();
  28. data.put("id", "111");
  29. data.put("name", "zhangsan");
  30. return data;
  31. }
  32. }

上述还有贴在class上面的注解:@RequestMapping(value = "/parent"),如果是class上面的注解,那么方法上面的url需要加上class上面的注解

如:http://localhost:8080/parent/get或http://localhost:8080/parent/add

其中可以属于请求参数和响应数据类型

  1. @RequestMapping(value = "/parent", consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)

其中consumes 约束入参类型,produces 约束响应数据类型

测试Content-Type:text/plain报错,由于设置了JSON格式

在这里插入图片描述

支持哪些格式参考Media定义

  1. org.springframework.http.MediaType

XML格式数据支持

这里扩展一下,返回XML格式数据

引入XML依赖包

  1. <dependency>
  2. <groupId>com.fasterxml.jackson.dataformat</groupId>
  3. <artifactId>jackson-dataformat-xml</artifactId>
  4. </dependency>

测试类

  1. @RestController
  2. public class DataRestContoller {
  3. @RequestMapping(value = "/addJsonResponseXml", consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_XML_VALUE)
  4. public Map<String, String> add(@RequestBody Map<String, String> data) {
  5. return data;
  6. }
  7. }

测试

在这里插入图片描述

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号