一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 使用@RequestBody 接收復雜實體類集合

使用@RequestBody 接收復雜實體類集合

2022-02-25 00:45羽渡塵 Java教程

這篇文章主要介紹了使用@RequestBody 接收復雜實體類集合方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

@RequestBody 接收復雜實體類集合

想要在 后臺接收josn返回的復雜List 直接給代碼

例:

@RequestMapping("/JsonSaveCustom")
public ResultVO JsonSaveCustom(HttpServletRequest request, @RequestBody bean_list objList) {
List<jsonbean> list = objList.getJsonbeans();
List<jsonbean> list2 = objList.getJsonbeans2();
System.out.println(list);
System.out.println(list2);
   return new ResultVO(true);
}

前臺: 以下只給例子 頁面具體的處理就不寫了 你是用循環添加什么的都可以 只要數據格式正確即可

var objList = {};
objList.flowid = '123456';
objList.id = 'abcdefg';
objList.roleid = '654321';

var jsonbeans = [];
var input = $(".budget_tableone").find("input");
   input.each(function () {
    jsonbeans.push({"name":$(this).attr("name"),"value":$(this).val().replace(/,/g,'β')});
   });
objList.jsonbeans = jsonbeans;

var jsonbeans2=[];
var table1 = $($($(".budget_tabletwo>table>tbody")[0])[0].children);
   table1.each(function (i) {
    var trList=[];
    $($(this)[0].children).each(function (j) {
     trList.push($(this).html().replace(/,/g,'β'));
    });
 jsonbeans2.push({"array":trList})//這里就是嵌套的
   });
   console.log(jsonbeans2)
   objList.jsonbeans2= jsonbeans2;
$.ajax({
       type:'post',
       dataType: "json",
       contentType: "application/json; charset=utf-8",
       url : '你的url',
       data : JSON.stringify(objList), 
       success : function(data){
       },
       error : function(){
           layeropen('2','發生意外錯誤!');
       }
   });

用到的實體類

/**
* JSON轉換實體類
* 
* @author XNYLH
*
*/
public class bean_list {
private String flowid;
private String id;
private String roleid;
private String agent;
private String stepid;
private List<jsonbean> jsonbeans;
private List<jsonbean> jsonbeans2;
private List<jsonbean> jsonbeans3;
public List<jsonbean> getJsonbeans() {
return jsonbeans;
}
public void setJsonbeans(List<jsonbean> jsonbeans) {
this.jsonbeans = jsonbeans;
}
public String getFlowid() {
return flowid;
}
public void setFlowid(String flowid) {
this.flowid = flowid;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getRoleid() {
return roleid;
}
public void setRoleid(String roleid) {
this.roleid = roleid;
}
public String getAgent() {
return agent;
}
public void setAgent(String agent) {
this.agent = agent;
}
public String getStepid() {
return stepid;
}
public void setStepid(String stepid) {
this.stepid = stepid;
}
public List<jsonbean> getJsonbeans2() {
return jsonbeans2;
}
public void setJsonbeans2(List<jsonbean> jsonbeans2) {
this.jsonbeans2 = jsonbeans2;
}
public List<jsonbean> getJsonbeans3() {
return jsonbeans3;
}
public void setJsonbeans3(List<jsonbean> jsonbeans3) {
this.jsonbeans3 = jsonbeans3;
}
}

用到的實體類

/**
* JSON轉換實體類
* 
* @author XNYLH
*
*/
/**
* JSON轉換實體類
* @author XNYLH
*
*/
public class jsonbean {
private String id;
private String name;
  private String value;
  private String [] array;
  
public String[] getArray() {
return array;
}
public void setArray(String[] array) {
this.array = array;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
@Override
public String toString() {
return "jsonbean [id=" + id + ", name=" + name + ", value=" + value + "]";
}    
}

數據格式

使用@RequestBody 接收復雜實體類集合

 

postman 模擬前端傳遞復雜對象及@RequestBody注解說明

后臺需要接收的對象格式如下:

使用@RequestBody 接收復雜實體類集合

使用@RequestBody 接收復雜實體類集合

使用postman模擬請求:

使用@RequestBody 接收復雜實體類集合

{
"name": "onion",
  "arrStr": [
      "1",
      "2",
      "3",
      "4",
      "5"
  ],
  "strList": [
      "1",
      "2",
      "3",
      "4",
      "5"
  ],
  "userInfoList": [
      {
          "id": 1,
          "userName": "jack1",
          "phone": "111",
          "address": "不哈",
          "password": "1123123",
          "createTime": ""
      },
      {
          "id": 2,
          "userName": "jack2",
          "phone": "111",
          "address": "不哈",
          "password": "1123123",
          "createTime": ""
      }
  ]
}

另外附帶講解一下@RequestBody 注解

@RequestBody主要用來接收前端傳遞給后端的json字符串中的數據的(請求體中的數據的);GET方式無請求體,所以使用@RequestBody接收數據時,前端不能使用GET方式提交數據,而是用POST方式進行提交。

在后端的同一個接收方法里,@RequestBody與@RequestParam()可以同時使用,@RequestBody最多只能有一個,而@RequestParam()可以有多個。

  • 注:一個請求,只有一個RequestBody;一個請求,可以有多個RequestParam。
  • 注:當同時使用@RequestParam()和@RequestBody時,@RequestParam()指定的參數可以是普通元素、數組、集合、對象等等(即:當,@RequestBody 與@RequestParam()可以同時使用時,原SpringMVC接收參數的機制不變,只不過RequestBody 接收的是請求體里面的數據;而RequestParam接收的是key-value里面的參數,所以它會被切面進行處理從而可以用普通元素、數組、集合、對象等接收)。即:如果參數時放在請求體中,傳入后臺的話,那么后臺要用@RequestBody才能接收到;如果不是放在請求體中的話,那么后臺接收前臺傳過來的參數時,要用@RequestParam來接收,或則形參前什么也不寫也能接收。
  • 注:如果參數前寫了@RequestParam(xxx),那么前端必須有對應的xxx名字才行(不管其是否有值,當然可以通過設置該注解的required屬性來調節是否必須傳),如果沒有xxx名的話,那么請求會出錯,報400。
  • 注:如果參數前不寫@RequestParam(xxx)的話,那么就前端可以有可以沒有對應的xxx名字才行,如果有xxx名的話,那么就會自動匹配;沒有的話,請求也能正確發送。追注:這里與feign消費服務時不同;feign消費服務時,如果參數前什么也不寫,那么會被默認是@RequestBody的。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/qq_36910987/article/details/93490396

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 狠狠插入| chinese一tk视频丨vk | 欧美黑人性猛交╳xx╳动态图 | 精品国产乱码久久久久久免费 | 欧美大片一级片 | 草莓绿巨人香蕉茄子芭乐 | 99视频精品国在线视频艾草 | 国产精品免费一级在线观看 | 999热这里全都是精品 | 精品国产乱码久久久久久免费 | 美女脱得一二净无内裤全身的照片 | 校园全黄h全肉细节文 | 男人猛进女人屁股免费 | 精品久久99麻豆蜜桃666 | 亚洲欧美日韩国产精品影院 | 四虎影院新地址 | 国产99在线| 日日碰碰 | 91影视在线看免费观看 | 日本在线亚州精品视频在线 | 好大好硬好深好爽想要小雪 | 美女沟厕撒尿全过程高清图片 | 东方影视欧美天天影院 | 亚洲狠狠婷婷综合久久久久网站 | 免费看欧美一级特黄a大片一 | 亚洲成色WWW久久网站夜月 | 深夜精品高中女学生 | 日本aa大片在线播放免费看 | 精品日韩一区二区三区 | 国产免费福利片 | 亚洲女bbwxxxx另类 | 久久久久久久久女黄 | 8插8插 | 久久人妻无码毛片A片麻豆 久久热这里只有 精品 | 精品国产线拍大陆久久尤物 | 天天操天天草 | 精品久久久久久影院免费 | 98pao强力打造高清免费 | 亚洲视频在线观看免费 | 三极片在线观看 | 5x视频在线观看 |