關(guān)于php中的json_encode()和json_decode()函數(shù)的一些說(shuō)明
一,json語(yǔ)法( php中的json_decode($json)中的$json要符合json語(yǔ)法格式 )
① JSON可以表示三種類型的值
1,簡(jiǎn)單值。包括整型,字符串型,布爾值和null。例如:5,"hello world",true,null都是有效的JSON數(shù)據(jù)。其中JSON字符串必須使用雙引號(hào)(單引號(hào)會(huì)導(dǎo)致語(yǔ)法錯(cuò)誤)。
2,對(duì)象。如,{"name":"tony","age":15}。說(shuō)明①要求屬性必須用雙引號(hào)(不加或者單引號(hào)都是錯(cuò)誤的)②值可以是簡(jiǎn)單值(注意若值為字符串,必須用雙引號(hào),不能用單引號(hào)),也可以是復(fù)雜類型的值(對(duì)象或數(shù)組)。
3,數(shù)組。如,[25,true,"tony"]。說(shuō)明:數(shù)組的值也可以是任意類型。
二,php定義對(duì)象字面量時(shí),不支持直接書(shū)寫(xiě),如{"a":"11","b":"22"}。這種書(shū)寫(xiě)方式在其他語(yǔ)言中被支持,在php中需要按如下方式定義:
① $a = '{"a":"11","b":"22"}' ;【這是json字符串,不加外面的單引號(hào)則是json對(duì)象】
② $b = json_decode($a);
這樣$b就是對(duì)象字面量了。
三,上述三種數(shù)值類型經(jīng)過(guò)json_encode($value)轉(zhuǎn)化后,會(huì)輸出json格式(此時(shí)類型為字符串),如"hello",{},[]。輸出的結(jié)果可以在其他地方(javascrip,ios,java,php等等)被解析使用。
四,php中改進(jìn)后的json_encode()和json_decode()函數(shù),支持漢語(yǔ)(原生的不支持漢語(yǔ))
注:php中不可直接改寫(xiě)原生函數(shù),需要寫(xiě)在類里,作為類的一個(gè)方法
static function json_encode($input)
{
// 從 PHP 5.4.0 起, 增加了這個(gè)選項(xiàng).
if (defined('JSON_UNESCAPED_UNICODE')) {
return json_encode($input, JSON_UNESCAPED_UNICODE);
}
if (is_string($input)) {
$text = $input;
$text = str_replace('\\', '\\\\', $text);
$text = str_replace(
array("\r", "\n", "\t", "\""),
array('\r', '\n', '\t', '\\"'),
$text);
return '"' . $text . '"';
} else if (is_array($input) || is_object($input)) {
$arr = array();
$is_obj = is_object($input) || (array_keys($input) !== range(0, count($input) - 1));
foreach ($input as $k => $v) {
if($v == null){
$v = 'null';
}
if ($is_obj) {
$arr[] = self::json_encode($k) . ':' . self::json_encode($v);
} else {
$arr[] = self::json_encode($v);
}
}
if ($is_obj) {
return '{' . join(',', $arr) . '}';
} else {
return '[' . join(',', $arr) . ']';
}
} else {
return $input . '';
}
}
以上這篇關(guān)于php中的json_encode()和json_decode()函數(shù)的一些說(shuō)明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- php中json_decode()和json_encode()的使用方法
- 淺析php中json_encode()和json_decode()
- PHP json_decode函數(shù)詳細(xì)解析
- PHP中遇到BOM、<feff>編碼導(dǎo)致json_decode函數(shù)無(wú)法解析問(wèn)題
- Javascript生成json的函數(shù)代碼(可以用php的json_decode解碼)
- php5.2以下版本無(wú)json_decode函數(shù)的解決方法
- php json_encode與json_decode詳解及實(shí)例
- PHP實(shí)現(xiàn)json_decode不轉(zhuǎn)義中文的方法
- 使用PHP json_decode可能遇到的坑與解決方法
相關(guān)文章
基于php實(shí)現(xiàn)七牛抓取遠(yuǎn)程圖片
由于公司網(wǎng)站之前的用戶頭像都是存儲(chǔ)在自己的服務(wù)器上的,后來(lái)感覺(jué)管理不方便,新增加的用戶頭像都上傳到了七牛,為了方便統(tǒng)一管理,領(lǐng)導(dǎo)說(shuō)把本地服務(wù)器的頭像全部遷移到了七牛2015-12-12
CodeIgniter框架驗(yàn)證碼類庫(kù)文件與用法示例
這篇文章主要介紹了CodeIgniter框架驗(yàn)證碼類庫(kù)文件與用法,結(jié)合實(shí)例形式分析了CodeIgniter框架驗(yàn)證碼類庫(kù)文件的定義與具體使用方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03
PHP實(shí)現(xiàn)支付寶即時(shí)到賬功能
這篇文章主要為大家詳細(xì)介紹了PHP實(shí)現(xiàn)支付寶即時(shí)到賬功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
php通過(guò)PHPExcel導(dǎo)入Excel表格到MySQL數(shù)據(jù)庫(kù)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇php通過(guò)PHPExcel導(dǎo)入Excel表格到MySQL數(shù)據(jù)庫(kù)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10
ThinkPHP實(shí)現(xiàn)批量刪除數(shù)據(jù)的代碼實(shí)例
這篇文章主要介紹了ThinkPHP實(shí)現(xiàn)批量刪除數(shù)據(jù)的代碼實(shí)例,需要的朋友可以參考下2014-07-07

