JSON處理是WordPress開發中的常常須要處理的一項工做,爲此WordPress 定義了一堆JSON處理的函數,下面由php中文網的WordPress教程欄目給你們作一下統一的介紹。php
wp_json_encodejson
編碼成 JSON,而且進行一些完整性檢查。數組
wp_json_encode( $data, $options = 0, $depth = 512 )app
簡單說下 WordPress 引進這個函數的緣由:wordpress
首先不一樣 PHP 版本 json_encode 函數支持不一樣的參數。PHP 5.3 以前只支持 一個參數 $data,PHP 5.3 引進了 $options 參數,PHP 5.5 又引進了 $depth 參數。因此 WordPress 適配不一樣版本的 PHP,wp_json_encode 都支持三個參數,兼容不一樣版本的 PHP。函數
在 json_encode 以前,wp_json_encode 使用函數 _wp_json_prepare_data 對數據進行清理,若是 boolean,integer,double,string,NULL 這些類型,直接返回,若是數組,繼續使用 _wp_json_prepare_data 函數對數組中的每一個元素進行清理,若是是對象,若是該對象的 class 實現了 JsonSerializable 接口,則返回 $data = $data->jsonSerialize(),不然,繼續使用 _wp_json_prepare_data 對對象中的每一個屬性進行清理。jsonp
而後使用 json_encode 進行編碼,若是不成功,則使用 _wp_json_sanity_check 對數據進行完整性處理,最後再使用 json_encode 進行編碼。_wp_json_sanity_check 主要使用函數 _wp_json_convert_string 對數據進行深度 UTF-8 檢測和轉換。編碼
因此建議使用 wp_json_encode 對變量進行 JSON 編碼,它的可靠性更高。插件
wpjam_json_encodecode
wp_json_encode( $data, $options = JSON_UNESCAPED_UNICODE, $depth = 512 )
PHP5.4 JSON 新增了一個選項:JSON_UNESCAPED_UNICODE,故名思議:不要編碼成 Unicode,讓中文更可讀。
因此咱們寫了一個 wpjam_json_encode 函數,相比 wp_json_encode,就是將 $options 參數默認值設置爲 JSON_UNESCAPED_UNICODE,這樣直接使用 wpjam_json_encode($data),中文就不會被編碼成 unicode,更可讀。
只要你安裝 WPJAM Basic 插件,你的 WordPress 就會有這個函數。
wp_send_json
直接發送 JSON 數據。
wp_send_json( $response, $status_code = null )
他首先輸出 application/json 的 Content-Type 頭,若是 $status_code 不爲空,則輸出 $status_code 的狀態碼。
而後調用 wp_json_encode 對數據進行編碼。
wpjam_send_json
wpjam_send_json( $response, $status_code = null )
一樣爲了可以 JSON 編碼以後,中文更可讀,咱們也寫了 wpjam_send_json 函數,它和 wp_send_json 幾乎一致,只是調用對數據進行編碼的函數是 wpjam_json_encode。
另外若是傳入的數據是 WP_Error 的實例,那麼 wpjam_send_json 直接輸出 errcode 和 errmsg JSON。若是沒有設置 errcode,則 wpjam_send_json 自動加上 errcode=>0
安裝 WPJAM Basic 插件,你的 WordPress 就會有這個函數。
wp_send_json_success 和 wp_send_json_error
WordPress 還提供 wp_send_json_success 和 wp_send_json_error 兩個函數:
wp_send_json_success( $data = null, $status_code = null )
wp_send_json_error( $data = null, $status_code = null )
wp_send_json_success 先輸出 success 爲 true,而後把數據 $data 放到 data 裏面輸出。wp_send_json_error 則會判斷 $data 是否爲 WP_Error 實例,若是是,則輸出 code 和 message 的數組。咱們實現的 wpjam_send_json 已經可以自動化處理這些錯誤了。
wp_is_json_request
判斷當前請求是否是 JSON 請求,或者返回 JSON 結果,這個函數沒有參數,直接使用:
wp_is_json_request()
它經過判斷 $_SERVER['HTTP_ACCEPT'] 中含有 application/json,或者 $_SERVER['CONTENT_TYPE'] 等於 application/json。
wp_is_jsonp_request
判斷當前請求是否是 JSONP 請求,或者返回 JSONP 結果,這個函數沒有參數,直接使用:
wp_is_jsonp_request()
它首先判斷 $_GET['_jsonp'] ,是否存在,而後經過函數 wp_check_jsonp_callback 判斷它的值是否合法。
wp_check_jsonp_callback
判斷 JSONP callback 是否是一個一個合法的 JavaScript callback 函數:
wp_check_jsonp_callback( $callback )
合法的 JavaScript callback 函數只能數字加字符,以及英文點號。