controller函數(shù)中參數(shù)列表使用多個(gè)@RequestBody問題
controller參數(shù)列表使用多個(gè)@RequestBody
首先出現(xiàn)這種情況是因?yàn)橛邢旅孢@種需求
$.ajax({ ?
?? ??? ? ? ?type: "POST", ?
?? ??? ? ? ?url: "${pageContext.request.contextPath}/courses", ?
?? ??? ? ? ?data: JSON.stringify({
?? ??? ? ? ??? ?course:course,
?? ??? ? ?courseInfoList:courseInfoList
?? ? ? ? ? }),//將對(duì)象序列化成JSON字符串 ?
?? ??? ? ? ?
?? ??? ? ? ?dataType:"json", ?
?? ??? ? ? ?contentType : 'application/json;charset=utf-8', //設(shè)置請(qǐng)求頭信息 ?
?? ??? ? ? ?success: function(data){ ?
?? ??? ? ? ?}, ?
?? ??? ? ? ?error: function(res){ ?
?? ??? ? ? ?} ?
?? ??? ?});?也就是在ajax傳輸數(shù)據(jù)時(shí)有多種數(shù)據(jù)類型在data域中
從而就會(huì)有下面這種controller
@RequestMapping(method = RequestMethod.POST ,consumes = "application/json")
?? ?public String createCourse(@RequestBody Course course, @RequestBody List<CourseInfo> courseInfoList)
?? ?{
?? ??? ?System.out.println(coursePackage.getCourse());
?? ??? ?System.out.println(coursePackage.getCourseInfoList());
?? ??? ?
?? ??? ?return "/createCourse";
?? ?}這樣就會(huì)出現(xiàn)400錯(cuò)誤,服務(wù)器無法理解這個(gè)請(qǐng)求
原因
@requestbody的含義是在當(dāng)前對(duì)象獲取整個(gè)http請(qǐng)求的body里面的所有數(shù)據(jù),因此spring就不可能將這個(gè)數(shù)據(jù)強(qiáng)制包裝成Course或者List類型,并且從@requestbody設(shè)計(jì)上來說,只獲取一次就可以拿到請(qǐng)求body里面的所有數(shù)據(jù),就沒必要出現(xiàn)有多個(gè)@requestbody出現(xiàn)在controller的函數(shù)的形參列表當(dāng)中
如果想解決這種問題
1.新建一個(gè)包裝上面兩種entity的entity類:
package com.yyc.entity;
?
import java.util.List;
?
public class CoursePackage {
?
?? ?public CoursePackage() {
?? ??? ?// TODO Auto-generated constructor stub
?? ?}
?? ?
?? ?private Course course;
?? ?
?? ?private List<CourseInfo> courseInfoList;
?? ?
?? ?public void setCourse(Course course)
?? ?{
?? ??? ?this.course = course;
?? ?}
?? ?
?? ?public void setCourseInfoList(List<CourseInfo> courseInfoList)
?? ?{
?? ??? ?this.courseInfoList = courseInfoList;
?? ?}
?? ?
?? ?public Course getCourse()
?? ?{
?? ??? ?return course;
?? ?}
?? ?
?? ?public List<CourseInfo> getCourseInfoList()
?? ?{
?? ??? ?return courseInfoList;
?? ?}
?
}然后將controller函數(shù)改為
@RequestMapping(method = RequestMethod.POST ,consumes = "application/json")
?? ?public String createCourse(@RequestBody CoursePackage coursePackage,Model model)
?? ?{
?? ??? ?System.out.println(coursePackage.getCourse());
?? ??? ?System.out.println(coursePackage.getCourseInfoList());
?? ??? ?return "/createCourse";
?? ?}但是這樣又顯得比較不夠簡(jiǎn)潔
2..用Map<String, Object>接受request body,自己反序列化到各個(gè)entity中。
@RequestBody是否存在的影響
首先 明確一點(diǎn)是 RequestBody注解的主要作用就是用于接收前端的參數(shù),當(dāng)我們使用post請(qǐng)求的時(shí)候,我們會(huì)將參數(shù)放在request body中,此時(shí)我們就需要在Controller的方法的參數(shù)前面加上@RequestBody用來接受到前端傳過來的request body中的值。
@PostMapping("/save")
? ? public Response<?> save(@RequestBody Insurance insurance){
? ? ? ? return null;
? ? }不使用@RequestBody注解時(shí),可以接收Content-Type為application/x-www-form-urlencoded類型的請(qǐng)求所提交的數(shù)據(jù),數(shù)據(jù)格式:aaa=111 b b b = 222 。
form 表單提交以及 jQuery的 bbb=222。form表單提交以及jQuery的bbb=222。form表單提交以及jQuery的.post()方法所發(fā)送的請(qǐng)求就是這種類型。
使用@RequestBody注解時(shí),用于接收Content-Type為application/json類型的請(qǐng)求,
數(shù)據(jù)類型是JSON:{“aaa”:“111”,“bbb”:“222”}
以上內(nèi)容來源于不同的資料內(nèi)容。
總是就是
當(dāng)入?yún)⒅挥幸粋€(gè)參數(shù)的時(shí)候,此時(shí)** @RequestBody **的注解是否存在沒有必要性,比如:String abcd;
那么前端傳參的時(shí)候:傳入
abcd = "1234";
{
abcd = "1234"
}二者的區(qū)別不是很大。
只有當(dāng)入?yún)⑤^多,或者是一個(gè)實(shí)體類入?yún)r(shí),加上該注解,前端以json的形式傳參,后臺(tái)才能接收到。
注意,如果多個(gè)值入?yún)?,比如:String aaa, String bbb,String ccc,
當(dāng)以這種形式入?yún)r(shí)需要加上**@RequestParam**注解,用于匹配各參數(shù)是否能一一對(duì)應(yīng)上。
@RequestParam:將請(qǐng)求參數(shù)綁定到你控制器的方法參數(shù)上(是springmvc中接收普通參數(shù)的注解)
語法:@RequestParam(value=”參數(shù)名”,required=”true/false”,defaultValue=””)
value:參數(shù)名required:是否包含該參數(shù),默認(rèn)為true,表示該請(qǐng)求路徑中必須包含該參數(shù),如果不包含就報(bào)錯(cuò)。defaultValue:默認(rèn)參數(shù)值,如果設(shè)置了該值,required=true將失效,自動(dòng)為false,如果沒有傳該參數(shù),就使用默認(rèn)值
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SrpingDruid數(shù)據(jù)源加密數(shù)據(jù)庫密碼的示例代碼
本篇文章主要介紹了SrpingDruid數(shù)據(jù)源加密數(shù)據(jù)庫密碼的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
Mybatis全局配置及映射關(guān)系的實(shí)現(xiàn)
本文主要介紹了Mybatis全局配置及映射關(guān)系的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
使用SpringBoot_jar方式啟動(dòng)并配置日志文件
這篇文章主要介紹了使用SpringBoot_jar方式啟動(dòng)并配置日志文件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
基于@MapperScan和@ComponentScan的使用區(qū)別
這篇文章主要介紹了@MapperScan和@ComponentScan的使用區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
spring?boot實(shí)現(xiàn)圖片上傳到后臺(tái)的功能(瀏覽器可直接訪問)
這篇文章主要介紹了spring?boot實(shí)現(xiàn)圖片上傳到后臺(tái)的功能(瀏覽器可直接訪問),需要的朋友可以參考下2022-04-04
Java利用布隆過濾器實(shí)現(xiàn)快速檢查元素是否存在
布隆過濾器是一個(gè)很長(zhǎng)的二進(jìn)制向量和一系列隨機(jī)映射函數(shù)。布隆過濾器可以用于檢索一個(gè)元素是否在一個(gè)集合中。本文就來詳細(xì)說說實(shí)現(xiàn)的方法,需要的可以參考一下2022-10-10
Java?Ribbon與openfeign區(qū)別和用法講解
Ribbon是基于Netflix?Ribbon實(shí)現(xiàn)的一套客戶端負(fù)載均衡的工具,主要功能是提供客戶端的軟件負(fù)載均衡算法和服務(wù)調(diào)用。openfeign對(duì)Feign進(jìn)行了增強(qiáng),使其支持Spring MVC注解,另外還整合了Ribbon和Nacos,從而使得Feign的使用更加方便2022-08-08

