原文链接:https://www.baeldung.com/spring-request-response-body
作者:baeldung
译者: helloworldtang
1. 引言
在这篇短文中,我们简要地介绍了Spring MVC中常用的注解 @RequestBody和@ResponseBody。
2. @RequestBody
简单地说,在@RequestBody注解的帮助下,Spring MVC会自动将HttpRequest body反序列化为一个Java对象,通常会将HttpRequest body映射到一个DTO或DO。
首先,让我们看一看Spring控制器方法:
@PostMapping("/request")public ResponseEntity postController(@RequestBody LoginForm loginForm) {exampleService.fakeAuthenticate(loginForm);return ResponseEntity.ok(HttpStatus.OK);}
如果HttpRequest body携带了正确的JSON,Spring MVC会自动将这个JSON反序列化为一个Java对象。通常情况下,我们必须将使用了@RequestBody标注的Java类与客户端发送的JSON相对应。
Tips:
bug高发区:Java类中的属性名与JSON中的键名必须完全一样,不一样的键值对是不会序列化到Java对象中的(⊙o⊙)哦。
public class LoginForm {private String username;private String password;// ...}
在这个例子中,我们将HttpRequest body映射到上面的这个LoginForm 对象。
让我们使用CURL来测试下这个接口:
curl -i \
-H "Accept: application/json" \-H "Content-Type:application/json" \-X POST --data'{"username": "johnny", "password": "password"}' "https://localhost:8080/.../request"
这就是一个Spring REST API以及使用@RequestBody 注解将Angular客户端发送的JSON自动序列化成Java对象所需要的全部内容了!
3. @ResponseBody
@ResponseBody注解告诉控制器,返回的对象需要自动序列化成JSON,并通过HttpResponse body返回给客户端。
Tips:
使用@ResponseBody注解修饰后,这个接口返回的将不是一个页面。
假设我们有一个自定义的Response对象,如下所示:
public class ResponseTransfer {private String text;// standard getters/setters}
接下来实现相应的控制器:
@Controller@RequestMapping("/post")public class ExamplePostController {@AutowiredExampleService exampleService;@PostMapping("/response")@ResponseBodypublic ResponseTransfer postResponseController(@RequestBody LoginForm loginForm) {return new ResponseTransfer("Thanks For Posting!!!");}}
在浏览器的开发者控制台或者使用像Postman这样的工具,我们可以看到以下的响应:
{"text": "Thanks For Posting!!!"}
请记住,如果控制器使用了@RestController注解,就不需要再使用 @ResponseBody了,因为它已经默认添加的。
Tips:
@RestController是一个组合注解,组合了@Controller和@ResponseBody。
4. 总结
我们已经为Spring应用构建了一个简单的Angular客户端,并演示了如何使用@RestController和@ResponseBody注解。
像往常一样,示例代码在GitHub上可以找到。
-END-
近期热文:
这位闯进程序员界的维密天使,她到底可以编出什么?!
如何从ActiveMQ平滑迁移到Kafka?
系统优化总结—系统层面
NIO相关基础篇
以Dubbo为例,聊聊如何为开源项目做贡献
25个面试中最常问的问题和答案
如何使用Spring优雅地处理REST异常?
Spring Cloud Finchley版中Consul多实例注册的问题处理
超有趣的几个Linux小命令
关注我
点击“阅读原文”,看本号其他精彩内容