@RequestBody的使用案例代码

基础知识介绍:
        @RequestBody主要用来接收前端传递给后端的json字符串中的数据的(请求体中的数据的);而最常用的使用请求体传参的无疑是POST请求了,所以使用@RequestBody接收数据时,一般都用POST方式进行提交。在后端的同一个接收方法里,@RequestBody与@RequestParam()可以同时使用,@RequestBody最多只能有一个,而@RequestParam()可以有多个。

注:一个请求,只有一个RequestBody;一个请求,可以有多个RequestParam。

注:当同时使用@RequestParam()和@RequestBody时,@RequestParam()指定的参数可以是普通元素、
       数组、集合、对象等等(即:当,@RequestBody 与@RequestParam()可以同时使用时,原SpringMVC接收
       参数的机制不变,只不过RequestBody 接收的是请求体里面的数据;而RequestParam接收的是key-value
       里面的参数,所以它会被切面进行处理从而可以用普通元素、数组、集合、对象等接收)。
       即:如果参数时放在请求体中,application/json传入后台的话,那么后台要用@RequestBody才能接收到;
             如果不是放在请求体中的话,那么后台接收前台传过来的参数时,要用@RequestParam来接收,或
             则形参前 什么也不写也能接收。

注:如果参数前写了@RequestParam(xxx),那么前端必须有对应的xxx名字才行(不管其是否有值,当然可以通
       过设置该注解的required属性来调节是否必须传),如果没有xxx名的话,那么请求会出错,报400。

注:如果参数前不写@RequestParam(xxx)的话,那么就前端可以有可以没有对应的xxx名字才行,如果有xxx名
       的话,那么就会自动匹配;没有的话,请求也能正确发送。
       追注:这里与feign消费服务时不同;feign消费服务时,如果参数前什么也不写,那么会被默认是
                  @RequestBody的。

下面介绍下@RequestBody的使用

@RequestBody是用来接收前端传到后端的json字符串的数据请求。

1.@RequestBody直接以String接收前端传过来的json数据:

2.@RequestBody以简单对象接收前端传过来的json数据:

3.@RequestBody以复杂对象接收前端传过来的json数据:
对象中含有数组或者集合,@RequestBody以复杂对象接收前端传过来的json数据。

public CommonResult init(@Valid @RequestBody InitRequest requestPayload) {
        // JSON to DTO
        InitRequestDto initDto = initRequestMapper.JsonToDtoMapper(requestPayload);
       Map resultList = new HashMap<>();
        resultList.put(Constants.PREVIEW_DATA_LIST, List);
        resultList.put(Constants.CHANGED_BODY, Body);
			return CommonResult.success(resultList);
@Getter
@Setter
@ToString
public class InitRequestDto {
	// 検索条件名
    // -
    protected String searchCriteriaName;

    // 検索条件
    // -
    protected String searchCriteria;
    
 	protected List messageUtilMcbMessagesDetailDtoList;
}

@RestController是组合注解返回json序列化。

@ConfigurationProperties 和 @Value 的区别:

​ @Configuration 的作用:Configuration用于定义配置类,可替换xml配置文件 , 将配置文件中的自定义属性批量注入到某个Bean中,

@ConfigurationProperties(prefix = "person")
@Data
public class Person {
    private int id;
    private String name;
    private List hobby;
    private String[] members;
    private Pet pet;
}

@Value 的作用:实现自定义属性的单个注入

@Component
public class Student {
    @Value("${person.id}")
    private int id;
    @Value("${person.name}")
    private String name;
    private List hobby;
}

@GetMapping和@RequestMapping的区别:

区别如下:

@GetMapping用于将HTTP get请求映射到特定处理程序的方法注解
具体来说,@GetMapping是一个组合注解,是@RequestMapping(method = RequestMethod.GET)的缩写。

@PostMapping用于将HTTP post请求映射到特定处理程序的方法注解
具体来说,@PostMapping是一个组合注解,是@RequestMapping(method = RequestMethod.POST)的缩写

@RequestMapping(method = RequestMethod.POST)

到此这篇关于@RequestBody的使用的文章就介绍到这了,更多相关@RequestBody的使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(@RequestBody的使用案例代码)