本文目錄一覽:
- 1、伺服器端怎麼接收Android客戶端傳過來的Json數據
- 2、接收到伺服器傳過來的json數據 怎麼轉成javascript對象
- 3、postman發送json數據 ,服務端接收json數據
- 4、.net mvc服務端怎麼接收客戶端的發送的json數據?
伺服器端怎麼接收Android客戶端傳過來的Json數據
android如果是通過http post發送數據的話,可以採用以下方式接收數據:
通過request.getParameter(paraName); 獲取參數。
request對象就是表示請求對象,getParameter就是獲取參數,傳遞的參數就是參數名。
例如請求 localhost:8080/web?data=abcd 則伺服器取值, request.getParameter(“data”); 。
接收到伺服器傳過來的json數據 怎麼轉成javascript對象
1. JSON的數據格式
a) 按照最簡單的形式,可以用下面這樣的 JSON 表示名稱/值對:
{ “firstName”: “Brett” }
b) 可以創建包含多個名稱/值對的記錄,比如:
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” }
c) 可以創建值的數組
{ “people”: [
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” },
{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” }
]}
d) 當然,可以使用相同的語法表示多個值(每個值包含多個記錄):
{ “programmers”: [
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” },
{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” }
],
“authors”: [
{ “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science fiction” },
{ “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” }
],
“musicians”: [
{ “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar” }
]
}
注意,在不同的主條目(programmers、authors 和 musicians)之間,記錄中實際的名稱/值對可以不一樣。JSON 是完全動態的,允許在 JSON 結構的中間改變表示數據的方式。
2. 在 JavaScript 中使用 JSON
JSON 是 JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON 數據不需要任何特殊的 API 或工具包。
2.1 將 JSON 數據賦值給變數
例如,可以創建一個新的 JavaScript 變數,然後將 JSON 格式的數據字元串直接賦值給它:
var people =
{ “programmers”: [
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” },
{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” }
],
“authors”: [
{ “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science fiction” },
{ “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” }
],
“musicians”: [
{ “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar” }
]
}
2.2 訪問數據
將這個數組放進 JavaScript 變數之後,就可以很輕鬆地訪問它。實際上,只需用點號表示法來表示數組元素。所以,要想訪問 programmers 列表的第一個條目的姓氏,只需在JavaScript 中使用下面這樣的代碼:
people.programmers[0].lastName;
注意,數組索引是從零開始的。
2.3 修改 JSON 數據
正如訪問數據,可以按照同樣的方式修改數據:
people.musicians[1].lastName = “Rachmaninov”;
2.4 轉換回字元串
a) 在 JavaScript 中這種轉換也很簡單:
String newJSONtext = people.toJSONString();
b) 可以將任何 JavaScript 對象轉換為 JSON 文本。並非只能處理原來用 JSON 字元串賦值的變數。為了對名為 myObject 的對象進行轉換,只需執行相同形式的命令:
String myObjectInJSON = myObject.toJSONString();
說明:將轉換回的字元串作為Ajax調用的字元串,完成非同步傳輸。
小結:如果要處理大量 JavaScript 對象,那麼 JSON 幾乎肯定是一個好選擇,這樣就可以輕鬆地將數據轉換為可以在請求中發送給伺服器端程序的格式。
3. 伺服器端的 JSON
3.1 將 JSON 發給伺服器
a) 通過 GET 以名稱/值對發送 JSON
在 JSON 數據中會有空格和各種字元,Web 瀏覽器往往要嘗試對其繼續編譯。要確保這些字元不會在伺服器上(或者在將數據發送給伺服器的過程中)引起混亂,需要在JavaScript的escape()函數中做如下添加:
var url = “organizePeople.php?people=” + escape(people.toJSONString());
request.open(“GET”, url, true);
request.onreadystatechange = updatePage;
request.send(null);
b) 利用 POST 請求發送 JSON 數據
當決定使用 POST 請求將 JSON 數據發送給伺服器時,並不需要對代碼進行大量更改,如下所示:
var url = “organizePeople.php?timeStamp=” + new Date().getTime();
request.open(“POST”, url, true);
request.onreadystatechange = updatePage;
request.setRequestHeader(“Content-Type”, “application/x-www-form-urlencoded”);
request.send(people.toJSONString());
注意:賦值時格式必須是var msg=eval(‘(‘ + req.responseText + ‘)’);
3.2 在伺服器上解釋 JSON
a) 處理 JSON 的兩步驟。
針對編寫伺服器端程序所用的語言,找到相應的 JSON 解析器/工具箱/幫助器 API。
使用 JSON 解析器/工具箱/幫助器 API 取得來自客戶機的請求數據並將數據轉變成腳本能理解的東西。
b) 尋找 JSON 解析器
尋找 JSON 解析器或工具箱最好的資源是 JSON 站點。如果使用的是 Java servlet,json.org 上的 org.json 包就是個不錯的選擇。在這種情況下,可以從 JSON Web 站點下載 json.zip 並將其中包含的源文件添加到項目構建目錄。編譯完這些文件後,一切就就緒了。對於所支持的其他語言,同樣可以使用相同的步驟;使用何種語言取決於您對該語言的精通程度,最好使用您所熟悉的語言。
c) 使用 JSON 解析器
一旦獲得了程序可用的資源,剩下的事就是找到合適的方法進行調用。如果在 servlet 中使用的是 org.json 包,則會使用如下代碼:
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
StringBuffer jb = new StringBuffer();
String line = null;
try {
BufferedReader reader = request.getReader();
while ((line = reader.readLine()) != null)
jb.append(line);
} catch (Exception e) { //report an error }
try {
JSONObject jsonObject = new JSONObject(jb.toString());
} catch (ParseException e) {
// crash and burn
throw new IOException(“Error parsing JSON request string”);
}
// Work with the data using methods like…
// int someInt = jsonObject.getInt(“intParamName”);
// String someString = jsonObject.getString(“stringParamName”);
// JSONObject nestedObj = jsonObject.getJSONObject(“nestedObjName”);
// JSONArray arr = jsonObject.getJSONArray(“arrayParamName”);
// etc…
}
postman發送json數據 ,服務端接收json數據
簡介:
postman是一個很好的http模擬器,在測試rest服務時是很好用的工具,可以發送get、post、put等各種請求。
發送json的具體步驟:
1、選擇post請求方式,同時將header的content-type設置為application/json
2、設置body的編碼方式為raw,application/json, raw是發送純文本,不包含任何空格的編碼方式
3、往下滾動滑鼠就能看到返回結果。
後端接收方式
我這邊用的是springboot
注意:
@ResponseBody 註解的使用:映射請求體
JsonNode 使用jackson框架,也可以使用其他的json框架或者bean
.net mvc服務端怎麼接收客戶端的發送的json數據?
在web程序開發中,前端和伺服器數據的傳輸方式常用的有兩種,一種是以表單的形式提交,此時可以利用jquery的serialize()方法將表單內容轉為a=1b=2c=3d=4e=5這樣的格式傳輸過去,接收端則可以用javabean直接接收。
還有一種方式是以json格式傳輸,接收時若直接用bean接收則接收不到,此時應該用@RequestBody方式,需要注意的是接收的需要是json串,而不是json對象,可以在發送前使用JSON.stringify函數進行處理。
例子如下
客戶端:
var url=path+’testConverter.html’;
$.ajax( {
url : url,
type : “POST”,
dataType:”json”,
contentType:’application/json;charset=UTF-8′,
data:JSON.stringify({userId:’1′,userName:’hello’,password:’test’,credits:’2′,lastIp:”,lastVisit:’1986-05-27′}),
success : function(data) {
alert(data.userName);
},
error:function(e){
alert(“err”);
}
服務端:
@RequestMapping(value=”/testConverter.html”)
@ResponseBody
public User testConverter(@RequestBody User user)
{
System.out.println(user.getUserName());
user.setUserName(“testname”);
return user;
}
上面例子中服務端返回的是個對象,@ResponseBody函數會自動將其轉換為客戶端要求的『 dataType:”json”,』格式。
最後需要注意的是
1,在xxx-serverlet配置文件中應該寫上,以便可以使用 @ResponseBody和@RequestBody
2,發送時要寫上 contentType:’application/json’
3,數組內容要用[]而不是list,用list會接收到一個map對象,而不是bean。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/151129.html