官术网_书友最值得收藏!

The RequestBody annotation

In this section, we will learn when and how to use the RequestBody annotation (@RequestBody) for handling web requests.

The RequestBody annotation is used to bind the method parameter with the body of the incoming request. In the process of binding, HttpMessageConverters converts the body of the request appropriately (most commonly into the parameter object) based on the content type of the request.

The RequestBody annotation is most commonly used in scenarios dealing with REST APIs. 

The following example demonstrates the usage of the @RequestBody annotation using a domain object, User, which is made a parameter to the controller method:

    @RestController
public class RestDemoController {

@PostMapping("/hello")
public HelloMessage getHelloMessage(@RequestBody User user) {
HelloMessage helloMessage = new HelloMessage();
String name = user.getName();
helloMessage.setMessage( "Hello " + name + "! How are you doing?");
helloMessage.setName(name);
return helloMessage;
}
}

In the preceding example, note some of the following:

  • The @PostMapping annotation maps the REST API endpoint, /hello, with the handler method, getHelloMessage. Recall that @PostMapping is a composed annotation which acts as a shortcut for @RequestMapping (method = RequestMethod.POST).
  • The @RequestBody annotation is used with the User object. This binds (or maps) the method parameter, user of type User, with the body of the web request. The body of the request arrives in the following JSON format:
        {"name": "Calvin Hobbes"}

The HttpMessageConverter method converts the preceding into the User object, whose code looks like the following:

    public class User {
private String name;

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}
}
  • The @RestController annotation, a convenient annotation, which is itself annotated with @Controller and @ResponseBody annotations, and is used for programming REST API integration endpoints.
  • The HelloMessage class is returned as a response. The following is the code for HelloMessage:
   public class HelloMessage {
private String message;
private String name;
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}

The HttpMessageConverter method converts the preceding response object into the following response message:

    {"message": "message text goes here...", "name": "name goes here..."}
主站蜘蛛池模板: 开化县| 泾川县| 德昌县| 新源县| 永丰县| 马山县| 望江县| 盱眙县| 宁海县| 仪征市| 玛曲县| 祁门县| 屯门区| 资溪县| 杨浦区| 桃园市| 汉阴县| 利川市| 呼伦贝尔市| 多伦县| 色达县| 北辰区| 新余市| 腾冲县| 大厂| 安福县| 勃利县| 南丹县| 大港区| 满洲里市| 静安区| 绥棱县| 徐水县| 永泰县| 木兰县| 山西省| 岱山县| 文成县| 建昌县| 东宁县| 盐山县|