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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美在线视频 一区二区 | a级免费在线观看 | 精彩国产萝视频在线 | 色网免费观看 | 幻女free性俄罗斯第一次摘花 | 国产成人综合久久精品红 | 91这里只有精品 | 98成人| 王晶经典三级 | 超级毛片 | 国产新疆成人a一片在线观看 | 日本不卡免费新一二三区 | 精品久久成人免费第三区 | 精品久久久久久久久免费影院 | 欧美日韩在线一区二区三区 | 公妇仑乱在线观看 | 亚洲AV国产国产久青草 | 色网在线观看 | 欧美日韩亚洲一区二区三区在线观看 | 午夜久久久久久网站 | 亚洲 欧美 国产 综合 在线 | 亚洲成a人不卡在线观看 | 疯狂伦交1一6 小说 风间由美在线 | 亚洲人的天堂男人爽爽爽 | 日本成熟老妇xxxx | 欧美成人禁片在线观看俄罗斯 | 花核调教 | 男人的私人影院 | 变态 另类 人妖小说 | 午夜国产精品福利在线观看 | 白丝尤物的下面被疯狂蹂躏 | 天堂va在线高清一区 | 成人啪精品视频免费网站 | 精品久久久久久久久久久 | 97精品国产高清在线看入口 | 日本免费精品 | 天天做天天爱天天一爽一毛片 | 欧洲女同同性videos0 | 国产精品国产三级在线专区 | 成人在线视频观看 | 国产美女做爰免费视频软件 |