使用ajax請求傳送複雜的json資料型別,並解決fastjson解析複雜的json資料型別的問題
環境:springboot框架
頁面:使用thymeleaf模板
html頁面:
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8"/>
<title>使用者登入</title>
<link rel="stylesheet" th:href="@{/css/bootstrap.css}"></link>
<script src="../static/js/jquery-1.7.2.js" type="text/javascript" th:src="@{/js/jquery-1.7.2.js}"></script>
<script type="text/javascript" th:inline="javascript">
function ajaxSubmit(){
var json = {"type":"學生","class":"2016級","obj":[{"user_name":"lisi","password":"123","name":"李四","age":"19"},{"user_name":"wangwu","password":"456","name":"王五","age":"19"}]}
var post={data:JSON.stringify(json)};
$.ajax({
url: [[@{/user/login}]],
type: "POST",
data: post,
dataType: "json",
success: function(data){
alert("解析複雜json資料成功")
},
error:function(err){
alert("解析複雜json資料成功失敗")
}
});
}
</script>
</head>
<body class="container">
<br/>
<h1>使用者登入</h1>
<br/><br/>
<div class="with:80%">
<button onclick="ajaxSubmit()">提交</button>
</div>
</body>
</html>
java程式碼:
@PostMapping("/user/login")
@ResponseBody
public void doLogin(Model model,String data){
///String parameter = request.getParameter("data");
//轉換成object
JSONObject jsonObj = JSON.parseObject(data);
//獲取jsonObj中obj欄位並轉換為陣列;
JSONArray result = jsonObj.getJSONArray("obj");
//把json裡面的集合封裝到List<User>中去
List<User> links= JSON.parseArray(result.toJSONString(),User.class);
//獲取jsonObj中type、class欄位;
String type = (String) jsonObj.get("type");
String className = (String) jsonObj.get("class");
System.out.println(">>>>>>>>>>>type>>>>>>>>>>"+type);
System.out.println(">>>>>>>>>>>className>>>>>>>>>>"+className);
for (User user : links) {
System.out.println(user.toString());
}
//集合轉換成json陣列
List<PaperPlan> list = new ArrayList<PaperPlan>();
JSONArray parseArray = JSONArray.parseArray(JSON.toJSONString(list));
}
相關文章
- hive複雜資料型別的用法Hive資料型別
- JAVA 解析複雜的json字串JavaJSON字串
- 複合型別(json)型別JSON
- 陣列轉json後的資料型別問題陣列JSON資料型別
- C語言中的複雜資料型別,你掌握了哪些?C語言資料型別
- jmeter之傳送json資料的post請求JMeterJSON
- Spring Boot 中使用 JSON Schema 來校驗複雜JSON資料Spring BootJSON
- javascript複雜型別如何傳參JavaScript型別
- [譯]在 Flutter 中解析複雜的 JSONFlutterJSON
- MySQL JSON資料型別操作MySqlJSON資料型別
- JSON 資料型別(轉載)JSON資料型別
- python 傳送buffer型別資料, 傳送octet-stream型別資料, 傳送Uint8Array型別資料Python型別UI
- Flutter解析複雜JSON泛型方案--拋磚引玉篇FlutterJSON泛型
- Python3 解析複雜結構的 jsonPythonJSON
- 學會用 Go 解析複雜 JSON 的思路GoJSON
- 一個複雜的json例子JSON
- [譯] 瞭解“多型”JSON 資料的效能問題多型JSON
- 簡單型別與複雜型別及原型鏈型別原型
- DataPipeline「自定義」資料來源,解決複雜請求邏輯外部資料獲取難題API
- vue開發黑科技--利用引用型別的值處理複雜資料的編輯Vue型別
- XML Schema 複雜元素型別詳解:定義及示例解析XML型別
- Mybatis讀取和儲存json型別的資料MyBatisJSON型別
- 拋磚系列之-MySQL中的資料型別JSONMySql資料型別JSON
- 46_初識搜尋引擎_mapping複雜資料型別以及object型別資料底層結構大揭秘APP資料型別Object
- http 請求 formData 型別資料HTTPORM型別
- mysql 5.7 json 型別 json 陣列型別 普通字串型別 10w資料 查詢速度差異MySqlJSON型別陣列字串
- Spark SQL:JSON資料來源複雜綜合案例實戰SparkSQLJSON
- json字串返回的資料有重複的資料JSON字串
- C#學習筆記--複雜資料型別、函式和結構體C#筆記資料型別函式結構體
- Solidity-變數和資料型別[複合型別_1]Solid變數資料型別
- 返回hash 型別的json型別JSON
- SAP UI5 初學者教程之十九 - SAP UI5 資料型別和複雜的資料繫結UI資料型別
- Typescript複雜型別的宣告:寫一個工具函式庫TypeScript型別函式
- Java雜記1—資料型別和變數Java資料型別變數
- 問題:JSON的格式型別到底有哪些呢?JSON型別
- C# 請求的名稱有效,但是找不到請求的型別的資料C#型別
- 基本資料型別與API引用型別的使用資料型別API
- 一文說透 MySQL JSON 資料型別(收藏)MySqlJSON資料型別