java獲取前端json數據_java如何獲取前端ajax傳來的json對象

假設使用 jQuery 中的 ajax

1. Json 對象

前端代碼示例

$.ajax({

url : 'http://localhost:8888/demo',

type: 'post',

data: {

'userName':'15488779956'

}

success: function(data) {

// TODO

}

})

后臺代碼示例

@RestController

public class Demo {

/**

* 方法 1 使用 HttpServletRequest 接收

* */

@RequestMapping("/demo")

public String getParam(HttpServletRequest request) {

return request.getParameter("userName");

}

/**

* 方法 2 使用 RequestParam 接收

* */

@RequestMapping("/demo2")

public String getParam2(@RequestParam(value = "userName") String userName) {

return userName;

}

/**

* 方法 3 與 方法 2 相同,只是變量名相同可以簡化書寫

* */

@RequestMapping("/demo3")

public String getParam3(String userName) {

return userName;

}

}

2. Json 字符串

$.ajax({

url : 'http://localhost:8888/demo',

type: 'post',

contentType:'application/json;charset=UTF-8',//關鍵

data: '{"userName":"15488779956"}',

success: function(data) {

// TODO

}

})

后臺示例代碼

@RestController

public class Demo {

/**

* 方法 1 使用 字符串分割獲取值

* */

@RequestMapping("/demo")

public Map getParam(HttpServletRequest request) {

// 獲取所有參數

Enumeration params = request.getParameterNames();

// 測試只有一條數據

String param = params.nextElement();

// 字符串分割

String paramKey = param.split(":")[0].replace("\"", "").replace("{", "");

String paramValue = param.split(":")[1].replace("\"", "").replace("}", "");

Map result = new HashMap<>();

result.put(paramKey, paramValue);

return result;

}

/**

* 方法 2 使用 Gson 與對應對象獲取值

* */

@RequestMapping("/demo2")

public Object getParam2(HttpServletRequest request) {

// 獲取所有參數

Enumeration params = request.getParameterNames();

// 測試只有一條數據

String param = params.nextElement();

Gson gson = new Gson();

return gson.fromJson(param, Req.class);

}

/**

* 方法 3 使用 Requestbody 實體進行接收

* */

@RequestMapping(value = "/demo3")

public String getParam3(@RequestBody Req s) {

System.out.println(s.toString());

return s.getUserName();

}

}

------------------------------------------------

/**

* 自定義的類,用于參數接收

* */

public class Req {

// 這個參數需要和 接收的數據 key 相同

private String userName;

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

@Override

public String toString() {

return "Req{" +

"userName='" + userName + '\'' +

'}';

}

}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/279153.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/279153.shtml
英文地址,請注明出處:http://en.pswp.cn/news/279153.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

版本控制介紹以及常用的版本控制工具

版本控制是指對軟件開發過程中各種程序代碼、配置文件及說明文檔等文件變更的管理&#xff0c;是軟件配置管理的核心思想之一。 編寫一個成熟可用的程序是一個工作量很大的工程&#xff0c;并非我們一次性就可以搞定的工作&#xff0c;所以在開發過程當中需要&#xff1a; 1、 …

2019年4月第四周_2012年4月最佳怪胎文章

2019年4月第四周This past month we covered topics such as how to use a 64-bit web browser on Windows, the best tips and tweaks for getting the most out of Firefox, how to check out library books on your Kindle for free, and more. Join us as we look back at …

matlab循環遍歷數組_Matlab - 訪問for循環中最大值的索引,并使用它從數組中刪除值...

我想遞歸地找到一系列矩陣中的最大值(第8列&#xff0c;具體)&#xff0c;然后使用該最大值的索引來設置數組中的所有值&#xff0c;索引最大為NaN的最大索引(對于列14:16) . 很容易找到最大值和索引&#xff0c;但是使用for循環為多個數組做這件事我很難過 .如果沒有for循環&a…

【資料整理】編譯安裝nginx

【nginx】編譯安裝nginx 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311…

游蕩的奶牛

沙雕題目 讀錯題了&#xff0c;不想多說 轉載于:https://www.cnblogs.com/bullshit/p/9811058.html

物體成癮性_科技成癮使我們不那么快樂。 那是一個市場機會。

物體成癮性Compulsively checking social networks makes us less happy. I think we all understand this intuitively, the same way we understand that working out more and eating better is a good idea. 強迫檢查社交網絡使我們不那么開心。 我認為我們所有人都可以憑直…

mysql 不要統計null_淺談為什么Mysql數據庫盡量避免NULL

在Mysql中很多表都包含可為NULL(空值)的列&#xff0c;即使應用程序并不需要保存NULL也是如此&#xff0c;這是因為可為NULL是列的默認屬性。但我們常在一些Mysql性能優化的書或者一些博客中看到觀點&#xff1a;在數據列中&#xff0c;盡量不要用NULL 值&#xff0c;使用0&…

Swing學習1——總體概述

以下來自于JDK1.6 一、Swing學習我劃分為兩個方面&#xff1a; 一方面Swing的界面設計部分&#xff0c;包括相關組件類的繼承關系&#xff0c;組件的功能用途&#xff0c;布局管理&#xff1b; 1.首先繼承關系上自上而下為 java.lang.Object java.awt.Component java.awt.Conta…

裝飾設計模式和例題

文件復制程序&#xff1a; 將一個文件復制一份出來&#xff0c;實現方法很簡單&#xff0c;使用FileInputStream讀取文件內容&#xff0c;然后使用FileOutputStream寫入另一個文件&#xff0c;利用read方法的返回值作為while循環的條件&#xff0c;進行一邊讀一邊寫。 代碼示例…

mysql操作手冊我_MySQL使用指南一

我將MySQL常用指令整理出來分享給大家。1. 列出所有數據庫mysql> show databases;2. 創建數據庫mysql> create databases MyStorage;3. 打開數據庫mysql> use MyStorage;4. 創建表mysql> create table Storage-> (-> id int,-> name varchar(50),-> pr…

谷歌地圖將很快顯示電動汽車充電站

If you’re out on the road in the future and find your electric vehicle is in dire need of a charge, you’ll soon be able to look to Google Maps for help finding a charging station. 如果您將來出門在外&#xff0c;并且發現您的電動汽車急需充電&#xff0c;那么…

JS4

1. js的本質就是處理數據。數據來自于后臺的數據庫。 所以變量就起到一個臨時存儲數據的作用。 ECMAScript制定了js的數據類型。 數據類型有哪些&#xff1f; 字符串 String數字 Number布爾 BooleanNull 空Undefined Object 對象Array 數組 json function …

ovirt官方安裝文檔 第三章

第3章&#xff1a;安裝oVirt 安裝oVirt引擎包 在您可以配置和使用oVirt引擎之前&#xff0c;您必須安裝 rhevm 包和依賴關系。 安裝oVirt引擎包 在開始安裝oVirt之前&#xff0c;添加官方倉庫&#xff1a; # yum install http://resources.ovirt.org/pub/yum-repo/ovirt-releas…

mysql獲取查詢策略語句_MySQL數據庫查詢性能優化策略

優化查詢使用Explain語句分析查詢語句Explain 用來分析 SELECT 查詢語句&#xff0c;開發人員可以通過分析 Explain 結果來優化查詢語句。通過對查詢語句的分析,可以了解查詢語句的執行情況,找出查詢語句執行的瓶頸,從而優化查詢語句.使用索引查詢MySql中提高性能的一個最有效的…

松弛變量可以為負嗎_如何為松弛安裝(非官方)暗模式

松弛變量可以為負嗎Slack still doesn’t have a dark mode. They have dark themes, but those only let you customize the sidebar colors, leaving the main window white. With the release of system-wide dark modes on macOS Mojave and Windows 10, Slack feels very …

如何使用系統自帶的日志轉儲功能logroate.存放應用日志

Linux日志服務介紹 &#xff11;. 在Linux系統&#xff0c;大部分日志都是由syslog日志服務驅動和管理的 syslog服務由兩個重要的配置文件控制管理&#xff0c;分別是/etc/syslog.conf主配置文件和/etc/sysconfig/syslog輔助 配置文件&#xff0c; /etc/init.d/syslog是啟動腳本…

shell 多行注釋

:<<BLOCK 中間為要注釋的內容 BLOCK轉載于:https://www.cnblogs.com/S--S/p/9817660.html

natcat for mysql_用Navicat for mysql連接mysql報錯1251-解決辦法

TP框架連接mongodb報錯及解決辦法mongodb版本3.4.7 1.認證錯誤:Failed to connect to: localhost:27017: Authentication failed on database test ...Loadrunner參數化連接oracle、mysql數據源報錯及解決辦法Loadrunner參數化連接oracle.mysql數據源報錯及解決辦法 (本人系統是…

如何在Mac上設置FaceTime

FaceTime is Apple’s built-in video and audio calling app. It pairs with your iPhone and allows you to make phone calls on macOS. FaceTime是Apple的內置視頻和音頻通話應用程序。 它可以與iPhone配對使用&#xff0c;并允許您在macOS上撥打電話。 You don’t need an…

移動視頻技術

在語音通信已得到教育、醫療、社交、電子商務等多個領域的移動應用和充分發展的今天&#xff0c;人們已不滿足于僅依靠語音電話來傳達信息。開發者都需要結合自身業務場景在其產品中嵌入語音聊天、視頻通話、語音對講等實時通話功能。但較高的技術門檻和開發成本成為普通開發者…