WordPress JSON處理相關函數(彙總)

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 函數只能數字加字符,以及英文點號。

相關文章
相關標籤/搜索