JSON是一種取代XML的數(shù)據(jù)結構,和xml相比,它更小巧但描述能力卻不差,由于它的小巧所以網(wǎng)絡傳輸數(shù)據(jù)將減少更多流量從而加快速度, 那么,JSON到底是什么?關于JSON關于JSONP。
var str1 = '{ "name": "cxh", "sex": "man" }'; var data=eval("("+str1+")");//轉換為json對象//data =(new alert (data.name);//會顯示出cxh
不過eval解析json有安全隱患!
現(xiàn)在大多數(shù)瀏覽器(IE8及以上,Chrome和Firefox差不多全部)自帶原生JSON對象,提供JSON.parse()方法解析JSON,提供JSON.stringify()方法生成JSON,請使用這兩個方法!
如果擔心parse()對對象拋異常,可以加一個封裝函數(shù):
JSON.pParse = function( tar ) { if( typeof( tar ) === 'string' ) { return JSON.parse( tar ); } else { return tar; } };
感謝oschina的 我土鱉 提供修改方法。
為了方便地處理JSON數(shù)據(jù),JSON提供了json.js包,下載地址:http://lib.sinaapp.com/js/json2/json2.js
在數(shù)據(jù)傳輸流程中,json是以文本,即字符串的形式傳遞的,而JS操作的是JSON對象,所以,JSON對象和JSON字符串之間的相互轉換是關鍵。例如:
JSON字符串:
var str1 = '{ "name": "cxh", "sex": "man" }';
JSON對象:
var str2 = { "name": "cxh", "sex": "man" };
一、JSON字符串轉換為JSON對象
要運用上面的str1,必須運用下面的要領先轉化為JSON對象:
var obj = eval('(' + str + ')');//由JSON字符串轉換為JSON對象
或則:
var obj = str.parseJSON(); //由JSON字符串轉換為JSON對象
或則:
var obj = JSON.parse(str); //由JSON字符串轉換為JSON對象
然后,就可以這樣讀?。?/p>
Alert(obj.name); Alert(obj.sex);
特別留心:如果obj本來就是一個JSON對象,那么運用 eval()函數(shù)轉換后(哪怕是多次轉換)還是JSON對象,但是運用 parseJSON()函數(shù)處理后會有疑問(拋出語法異常)。
二、可以運用 toJSONString()或者全局要領 JSON.stringify()將JSON對象轉化為JSON字符串。
例如:
var last=obj.toJSONString(); //將JSON對象轉化為JSON字符
或則:
var last=JSON.stringify(obj); //將JSON對象轉化為JSON字符 alert(last);
留心:
上面的多個要領中,除了eval()函數(shù)是js自帶的之外,其他的多個要領都來自json.js包。新版本的 JSON 修改了 API,將 JSON.stringify() 和 JSON.parse() 兩個要領都注入到了 Javascript 的內(nèi)建對象里面,前者變成了 Object.toJSONString(),而后者變成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()要領,則說明您的json包版本太低。
語法:
jQuery.getJSON(url,data,success(data,status,xhr))
參數(shù):
參數(shù) | 描述 |
---|---|
url | 必需。規(guī)定將請求發(fā)送的哪個 URL。 |
data | 可選。規(guī)定連同請求發(fā)送到服務器的數(shù)據(jù)。 |
success(data,status,xhr) | 可選。規(guī)定當請求成功時運行的函數(shù)。 額外的參數(shù):
|
用例:
$.getJSON("test.js", function(json){ alert("JSON Data: " + json.users[3].name); });
這個需要json-lib.jar包支持 該jar下載地址:點擊下載
//JSON對象 JSONObject的使用 String str1 = "{ 'name': 'cxh', 'sex': '1' }"; JSONObject obj = JSONObject.fromObject(str1); String name = obj.getString("name"); //直接返回字符串型 cxh Object nameo = obj.get("name"); //直接返回對象型的cxh int age = obj.getInt("sex"); //直接返回int型的sex //JSON數(shù)組對象 JSONArray的運用 String jsonArrStr = "[{ 'name': 'cxh', 'sex': '1','website':'http://www.ctyr.cn' },{ 'name': '三少', 'sex': '1','website':'http://www.ij2ee.com' }]"; JSONArray array = JSONArray.fromObject(jsonArrStr); int size = array.size(); //獲取JSON數(shù)組大小 JSONObject jo = array.getJSONObject(0);//取第一個JSON對象 for(int i=0;i<size;i++){ JSONObject jo1 = array.getJSONObject(i); System.out.println(jo1.getString("website")); //循環(huán)返回網(wǎng)址 } //序列化Bean對象為JSON對象 User user = new User(); user.setName("cxh"); user.setSex(1); user.setWebsite("http://www.ctyr.cn"); JSONObject jo2 = JSONObject.fromObject(user); System.out.println(jo2.toString()); //則會輸出 { 'name': 'cxh', 'sex': '1','website':'http://www.ctyr.cn' }
一、json_encode()
該函數(shù)主要用來將數(shù)組和對象,轉換為json格式。先看一個數(shù)組轉換的例子:
$arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5); echo json_encode($arr);
結果為:
{"a":1,"b":2,"c":3,"d":4,"e":5}
再看一個對象轉換的例子:
$obj->body = 'another post'; $obj->id = 21; $obj->approved = true; $obj->favorite_count = 1; $obj->status = NULL; echo json_encode($obj);
結果為:
{ "body":"another post", "id":21, "approved":true, "favorite_count":1, "status":null }
由于json只接受utf-8編碼的字符,所以json_encode()的參數(shù)必須是utf-8編碼,否則會得到空字符或者null。當中文使用GB2312編碼,或者外文使用ISO-8859-1編碼的時候,這一點要特別注意。
二、索引數(shù)組和關聯(lián)數(shù)組
PHP支持兩種數(shù)組,一種是只保存"值"(value)的索引數(shù)組(indexed array),另一種是保存"名值對"(name/value)的關聯(lián)數(shù)組(associative array)。 由于javascript不支持關聯(lián)數(shù)組,所以json_encode()只將索引數(shù)組(indexed array)轉為數(shù)組格式,而將關聯(lián)數(shù)組(associative array)轉為對象格式。 比如,現(xiàn)在有一個索引數(shù)組
$arr = Array('one', 'two', 'three'); echo json_encode($arr);
結果為:
["one","two","three"]
如果將它改為關聯(lián)數(shù)組:
$arr = Array('1'=>'one', '2'=>'two', '3'=>'three'); echo json_encode($arr);
結果就變了:
{"1":"one","2":"two","3":"three"}
注意,數(shù)據(jù)格式從"[]"(數(shù)組)變成了"{}"(對象)。
如果你需要將"索引數(shù)組"強制轉化成"對象",可以這樣寫:
json_encode( (object)$arr );
或者:
json_encode ( $arr, JSON_FORCE_OBJECT );
三、類(class)的轉換
下面是一個PHP的類:
class Foo { const ERROR_CODE = '404'; public $public_ex = 'this is public'; private $private_ex = 'this is private!'; protected $protected_ex = 'this should be protected'; public function getErrorCode() { return self::ERROR_CODE; } }
現(xiàn)在,對這個類的實例進行json轉換:
$foo = new Foo; $foo_json = json_encode($foo); echo $foo_json;
輸出結果是:
{"public_ex":"this is public"}
可以看到,除了公開變量(public),其他東西(常量、私有變量、方法等等)都遺失了。
四、json_decode()
該函數(shù)用于將json文本轉換為相應的PHP數(shù)據(jù)結構。下面是一個例子:
$json = '{"foo": 12345}'; $obj = json_decode($json); print $obj->{'foo'}; // 12345
通常情況下,json_decode()總是返回一個PHP對象,而不是數(shù)組。比如:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json));
結果就是生成一個PHP對象:
object(stdClass)#1 (5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }
如果想要強制生成PHP關聯(lián)數(shù)組,json_decode()需要加一個參數(shù)true:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json,true));
結果就生成了一個關聯(lián)數(shù)組:
array(5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }
五、json_decode()的常見錯誤
$bad_json = "{ 'bar': 'baz' }"; $bad_json = '{ bar: "baz" }'; $bad_json = '{ "bar": "baz", }';
對這三個字符串執(zhí)行json_decode()都將返回null,并且報錯。
第一個的錯誤是,json的分隔符(delimiter)只允許使用雙引號,不能使用單引號。第二個的錯誤是,json名值對的"名"(冒號左邊的部分),任何情況下都必須使用雙引號。第三個的錯誤是,最后一個值之后不能添加逗號(trailing comma)。
另外,json只能用來表示對象(object)和數(shù)組(array),如果對一個字符串或數(shù)值使用json_decode(),將會返回null。
var_dump(json_decode("Hello World")); //null
import json str1 = '{ "name": "cxh", "sex": "1" }' # 或者 # str1 = """{ "name": "cxh", "sex": "1" }""" # 或者 # str1 = "{ \"name\": \"cxh\", \"sex\": \"1\" }" obj = json.loads(str1) print(obj["name"]) print(obj["sex"]) # 由于出現(xiàn)中文,記得文件頭加入 # coding:utf8 json_arr_str = """[{ "name": "cxh", "sex": "1","website":"http://www.ctyr.cn" },{ "name": "我的", "sex": "1","website":"http://www.ctyr.cn" }]""" arr = json.loads(json_arr_str) for o in arr: print(o["name"]) print(o["sex"]) print(o["website"])
謝謝【張東桂】提供的代碼
需要的dll:Newtonsoft.Json.dll,dll官網(wǎng)下載
//讀取簡單的json string json="{\"username\":\"張三\"}"; string username = string.Empty; JObject jObj=JObject.Parse(json); //進行格式化 username = jObj["username"].ToString(); Console.WriteLine(username); //讀取嵌套對象的json json = "{\"username\":\"張三\",data:{\"address\":\"福建廈門\"}}"; jObj = JObject.Parse(json); string address = string.Empty; address = jObj["data"]["address"].ToString(); Console.WriteLine(address); //讀取數(shù)組,操作方式與數(shù)組類似 json = "{\"username\":\"張三\",data:[{\"address\":\"福建廈門\"},{\"address\":\"福建福州\"}]}"; jObj = JObject.Parse(json); address = string.Empty; address = jObj["data"][0]["address"].ToString()+","+ jObj["data"][1]["address"].ToString(); Console.WriteLine(address); Console.ReadLine();
謝謝【黃明輝】提供的代碼
需要的dll:Newtonsoft.Json.dll,dll官網(wǎng)下載
//JSON字符串轉字典: NSString *str1 = @"{\"name\":\"cxh\",\"sex\":\"1\"}"; NSData *jsonData1 = [str1 dataUsingEncoding:NSUTF8StringEncoding]; NSError *error1; NSDictionary *jsonDic = [NSJSONSerialization JSONObjectWithData:jsonData1 options:NSJSONReadingMutableContainers error:&error1]; /* NSJSONReadingMutableContainers 創(chuàng)建結果為可變數(shù)組/字典 NSJSONReadingMutableLeaves 創(chuàng)建結果中字符串是可變字符串 NSJSONReadingAllowFragments 允許json最外層不是數(shù)組或字典 */ if (!error1) { NSLog(@"jsonDic is:%@",jsonDic); } else{ NSLog(@"error:%@",error1); } //字典轉JSON字符串 NSError *error2 = nil; NSData *jsonData2 = [NSJSONSerialization dataWithJSONObject:jsonDic options:NSJSONWritingPrettyPrinted error:&error2]; if (!error2) { NSString *str2 = [[NSString alloc] initWithData:jsonData2 encoding:NSUTF8StringEncoding]; NSLog(@"json string is:%@",str2); } else{ NSLog(@"error:%@",error2); }
有要補充的,請把代碼和所需要的支持庫發(fā)送到我的郵箱 ij2ee@139.com,被采用的可以加上您的網(wǎng)站外鏈哦。
您最近使用了: