本文實(shí)例講述了PHP 實(shí)現(xiàn) JSON 數(shù)據(jù)的編碼和解碼操作。分享給大家供大家參考,具體如下:
JSON 的使用場景:
- 數(shù)據(jù)表一個(gè)字段需要記錄多個(gè)信息,如記錄關(guān)于用戶的其他信息
- 數(shù)據(jù)傳輸,如:API接口返回值、Ajax中實(shí)現(xiàn)異步加載
- 配置文件,如 composer.json 包管理配置文件
在 PHP 中使用 JSON:
JSON 使用最頻繁的兩個(gè)操作就是編碼和解析數(shù)據(jù),PHP 官方提供了以下 2 個(gè)函數(shù)實(shí)現(xiàn)這兩個(gè)操作:
- json_encode()
- json_decode()
Encoding and Decoding
編碼用于將數(shù)據(jù)綁定到特定格式。需要此過程來保持?jǐn)?shù)據(jù)一致性。解碼是一個(gè)反向過程,它將編碼的數(shù)據(jù)還原回其原始形式。
PHP JSON Encode
使用 json_encode 將 PHP 的一些數(shù)據(jù)類型轉(zhuǎn)換為 JSON 格式,函數(shù)包含 3 個(gè)參數(shù),分別為:
- 將要編碼的數(shù)據(jù)
- 帶有 JSON encode 常量的選項(xiàng)可以反映對(duì)編碼行為的影響
- 編碼的深度限制
PHP 中預(yù)定義的 JSON 常量
JSON_FORCE_OBJECT
JSON_HEX_QUOT
JSON_HEX_TAG
JSON_HEX_AMP
JSON_HEX_APOS
JSON_INVALID_UTF8_IGNORE
JSON_INVALID_UTF8_SUBSTITUTE
JSON_NUMERIC_CHECK
JSON_PARTIAL_OUTPUT_ON_ERROR
JSON_PRESERVE_ZERO_FRACTION
JSON_PRETTY_PRINT
JSON_UNESCAPED_LINE_TERMINATORS
JSON_UNESCAPED_SLASHES
JSON_UNESCAPED_UNICODE
JSON_THROW_ON_ERROR
Example: PHP json_encode()
?php
$input_array = array("zero","one","two");
//returns ["zero","one","two"]
$str_json_format = json_encode($input_array);
print "JSON Formatted String:" . $str_json_format;
//returns {"0":"zero","1":"one","2":"two"}
$obj_json_format = json_encode($input_array, JSON_FORCE_OBJECT);
print "br/>br/>JSON Object:" . $obj_json_format;
//returns [ "zero", "one", "two" ]
$strJsonFormat_with_space = json_encode($input_array, JSON_PRETTY_PRINT);
print "br/>br/>JSON Formatted String with white space:" . $strJsonFormat_with_space;
PHP JSON Decode
這是 JSON encode 的反向操作,用于將 JSON 編碼的數(shù)據(jù)轉(zhuǎn)換為最初編碼的 PHP數(shù)據(jù)類型。
json_decode 函數(shù)包含 4 個(gè)參數(shù),分別為:
- 將要解析的 JSON 字符串
- 當(dāng)該參數(shù)為
TRUE
時(shí),將返回 array 而非 object
- 指定遞歸深度
- JSON 常量
JSON_BIGINT_AS_STRING
, JSON_INVALID_UTF8_IGNORE
, JSON_INVALID_UTF8_SUBSTITUTE
, JSON_OBJECT_AS_ARRAY
, JSON_THROW_ON_ERROR
返回值:
返回值為 TRUE
, FALSE
和 NULL
。
如果 json
無法被解碼, 或者編碼數(shù)據(jù)深度超過了遞歸限制的話,將會(huì)返回NULL
Example: PHP json_encode()
?php
$str_json_array_decoded = json_decode($str_json_format);
print "br/>br/>Resultant decoded array from JSON array:br/>";
print "PRE>";
print_r($str_json_array_decoded);
print "/PRE>";
$str_objJson_decoded = json_decode($obj_json_format);
print "br/>br/>Resultant decoded object data from JSON object:br/>";
print "PRE>";
print_r($str_objJson_decoded);
print "/PRE>";
$str_jsonAry_decoded = json_decode($obj_json_format,true);
print "br/>br/>Resultant decoded array data from JSON object:br/>";
print "PRE>";
print_r($str_jsonAry_decoded);
print "/PRE>";
注意:
- PHP 可以將任意數(shù)據(jù)類型轉(zhuǎn)換為 JSON 格式,除了 resource data
- JSON 解碼時(shí),必須先去除掉字符串中的反斜杠 "\",不然會(huì)導(dǎo)致解析失敗,可以使用
stripslashes
對(duì)字符串進(jìn)行處理后,再使用 json_decode 解析
如果需要解碼的 JSON 數(shù)據(jù)中包含有反斜杠 "\",應(yīng)該使用如下代碼進(jìn)行解碼:
$obj = \json_decode(stripslashes($json));
PS:這里再為大家推薦幾款比較實(shí)用的json在線工具供大家參考使用:
在線JSON代碼檢驗(yàn)、檢驗(yàn)、美化、格式化工具:
http://tools.jb51.net/code/json
JSON在線格式化工具:
http://tools.jb51.net/code/jsonformat
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
C語言風(fēng)格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP中json格式數(shù)據(jù)操作技巧匯總》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- 淺談php和js中json的編碼和解碼
- php中json_encode中文編碼問題分析
- PHP學(xué)習(xí)散記_編碼(json_encode 中文不顯示)
- PHP中遇到BOM、feff>編碼導(dǎo)致json_decode函數(shù)無法解析問題
- php使用json_encode對(duì)變量json編碼
- php json中文編碼為null的解決辦法
- java解析php函數(shù)json_encode unicode 編碼問題
- php5.2 Json不能正確處理中文、GB編碼的解決方法
- php實(shí)現(xiàn)json編碼的方法
- PHP自定義遞歸函數(shù)實(shí)現(xiàn)數(shù)組轉(zhuǎn)JSON功能【支持GBK編碼】