欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

@RequestBody的使用案例代碼

 更新時(shí)間:2023年02月04日 10:01:21   作者:理所襠燃  
@RequestBody主要用來接收前端傳遞給后端的json字符串中的數(shù)據(jù)的,這篇文章主要介紹了@RequestBody的使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

基礎(chǔ)知識(shí)介紹:
        @RequestBody主要用來接收前端傳遞給后端的json字符串中的數(shù)據(jù)的(請(qǐng)求體中的數(shù)據(jù)的);而最常用的使用請(qǐng)求體傳參的無疑是POST請(qǐng)求了,所以使用@RequestBody接收數(shù)據(jù)時(shí),一般都用POST方式進(jìn)行提交。在后端的同一個(gè)接收方法里,@RequestBody與@RequestParam()可以同時(shí)使用,@RequestBody最多只能有一個(gè),而@RequestParam()可以有多個(gè)。

注:一個(gè)請(qǐng)求,只有一個(gè)RequestBody;一個(gè)請(qǐng)求,可以有多個(gè)RequestParam。

注:當(dāng)同時(shí)使用@RequestParam()和@RequestBody時(shí),@RequestParam()指定的參數(shù)可以是普通元素、
       數(shù)組、集合、對(duì)象等等(即:當(dāng),@RequestBody 與@RequestParam()可以同時(shí)使用時(shí),原SpringMVC接收
       參數(shù)的機(jī)制不變,只不過RequestBody 接收的是請(qǐng)求體里面的數(shù)據(jù);而RequestParam接收的是key-value
       里面的參數(shù),所以它會(huì)被切面進(jìn)行處理從而可以用普通元素、數(shù)組、集合、對(duì)象等接收)。
       即:如果參數(shù)時(shí)放在請(qǐng)求體中,application/json傳入后臺(tái)的話,那么后臺(tái)要用@RequestBody才能接收到;
             如果不是放在請(qǐng)求體中的話,那么后臺(tái)接收前臺(tái)傳過來的參數(shù)時(shí),要用@RequestParam來接收,或
             則形參前 什么也不寫也能接收。

注:如果參數(shù)前寫了@RequestParam(xxx),那么前端必須有對(duì)應(yīng)的xxx名字才行(不管其是否有值,當(dāng)然可以通
       過設(shè)置該注解的required屬性來調(diào)節(jié)是否必須傳),如果沒有xxx名的話,那么請(qǐng)求會(huì)出錯(cuò),報(bào)400。

注:如果參數(shù)前不寫@RequestParam(xxx)的話,那么就前端可以有可以沒有對(duì)應(yīng)的xxx名字才行,如果有xxx名
       的話,那么就會(huì)自動(dòng)匹配;沒有的話,請(qǐng)求也能正確發(fā)送。
       追注:這里與feign消費(fèi)服務(wù)時(shí)不同;feign消費(fèi)服務(wù)時(shí),如果參數(shù)前什么也不寫,那么會(huì)被默認(rèn)是
                  @RequestBody的。

下面介紹下@RequestBody的使用

@RequestBody是用來接收前端傳到后端的json字符串的數(shù)據(jù)請(qǐng)求。

1.@RequestBody直接以String接收前端傳過來的json數(shù)據(jù):

2.@RequestBody以簡單對(duì)象接收前端傳過來的json數(shù)據(jù):

3.@RequestBody以復(fù)雜對(duì)象接收前端傳過來的json數(shù)據(jù):
對(duì)象中含有數(shù)組或者集合,@RequestBody以復(fù)雜對(duì)象接收前端傳過來的json數(shù)據(jù)。

public CommonResult<?> init(@Valid @RequestBody InitRequest requestPayload) {
        // JSON to DTO
        InitRequestDto initDto = initRequestMapper.JsonToDtoMapper(requestPayload);
       Map<String, Object> 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<MessageUtilMcbMessagesDetailDto> messageUtilMcbMessagesDetailDtoList;
}

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

@ConfigurationProperties 和 @Value 的區(qū)別:

? @Configuration 的作用:Configuration用于定義配置類,可替換xml配置文件 , 將配置文件中的自定義屬性批量注入到某個(gè)Bean中,

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

@Value 的作用:實(shí)現(xiàn)自定義屬性的單個(gè)注入

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

@GetMapping和@RequestMapping的區(qū)別:

區(qū)別如下:

@GetMapping用于將HTTP get請(qǐng)求映射到特定處理程序的方法注解
具體來說,@GetMapping是一個(gè)組合注解,是@RequestMapping(method = RequestMethod.GET)的縮寫。

@PostMapping用于將HTTP post請(qǐng)求映射到特定處理程序的方法注解
具體來說,@PostMapping是一個(gè)組合注解,是@RequestMapping(method = RequestMethod.POST)的縮寫

@RequestMapping(method = RequestMethod.POST)

到此這篇關(guān)于@RequestBody的使用的文章就介紹到這了,更多相關(guān)@RequestBody的使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論