創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買多久送多久,劃算不套路!
疊彩ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!小編給大家分享一下WordPress JSON處理相關(guān)函數(shù)的案例,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
JSON處理是WordPress開發(fā)中的經(jīng)常需要處理的一項(xiàng)工作,為此WordPress 定義了一堆JSON處理的函數(shù),下面由WordPress教程欄目給大家做一下統(tǒng)一的介紹。
wp_json_encode
編碼成 JSON,并且進(jìn)行一些完整性檢查。
wp_json_encode( $data, $options = 0, $depth = 512 )
簡(jiǎn)單說下 WordPress 引進(jìn)這個(gè)函數(shù)的原因:
首先不同 PHP 版本 json_encode 函數(shù)支持不同的參數(shù)。PHP 5.3 之前只支持 一個(gè)參數(shù) $data,PHP 5.3 引進(jìn)了 $options 參數(shù),PHP 5.5 又引進(jìn)了 $depth 參數(shù)。所以 WordPress 適配不同版本的 PHP,wp_json_encode 都支持三個(gè)參數(shù),兼容不同版本的 PHP。
在 json_encode 之前,wp_json_encode 使用函數(shù) _wp_json_prepare_data 對(duì)數(shù)據(jù)進(jìn)行清理,如果 boolean,integer,double,string,NULL 這些類型,直接返回,如果數(shù)組,繼續(xù)使用 _wp_json_prepare_data 函數(shù)對(duì)數(shù)組中的每個(gè)元素進(jìn)行清理,如果是對(duì)象,如果該對(duì)象的 class 實(shí)現(xiàn)了 JsonSerializable 接口,則返回 $data = $data->jsonSerialize(),否則,繼續(xù)使用 _wp_json_prepare_data 對(duì)對(duì)象中的每個(gè)屬性進(jìn)行清理。
然后使用 json_encode 進(jìn)行編碼,如果不成功,則使用 _wp_json_sanity_check 對(duì)數(shù)據(jù)進(jìn)行完整性處理,最后再使用 json_encode 進(jìn)行編碼。_wp_json_sanity_check 主要使用函數(shù) _wp_json_convert_string 對(duì)數(shù)據(jù)進(jìn)行深度 UTF-8 檢測(cè)和轉(zhuǎn)換。
所以建議使用 wp_json_encode 對(duì)變量進(jìn)行 JSON 編碼,它的可靠性更高。
wpjam_json_encode
wp_json_encode( $data, $options = JSON_UNESCAPED_UNICODE, $depth = 512 )
PHP5.4 JSON 新增了一個(gè)選項(xiàng):JSON_UNESCAPED_UNICODE,故名思議:不要編碼成 Unicode,讓中文更可讀。
所以我們寫了一個(gè) wpjam_json_encode 函數(shù),相比 wp_json_encode,就是將 $options 參數(shù)默認(rèn)值設(shè)置為 JSON_UNESCAPED_UNICODE,這樣直接使用 wpjam_json_encode($data),中文就不會(huì)被編碼成 unicode,更可讀。
只要你安裝 WPJAM Basic 插件,你的 WordPress 就會(huì)有這個(gè)函數(shù)。
wp_send_json
直接發(fā)送 JSON 數(shù)據(jù)。
wp_send_json( $response, $status_code = null )
他首先輸出 application/json 的 Content-Type 頭,如果 $status_code 不為空,則輸出 $status_code 的狀態(tài)碼。
然后調(diào)用 wp_json_encode 對(duì)數(shù)據(jù)進(jìn)行編碼。
wpjam_send_json
wpjam_send_json( $response, $status_code = null )
同樣為了能夠 JSON 編碼之后,中文更可讀,我們也寫了 wpjam_send_json 函數(shù),它和 wp_send_json 幾乎一致,只是調(diào)用對(duì)數(shù)據(jù)進(jìn)行編碼的函數(shù)是 wpjam_json_encode。
另外如果傳入的數(shù)據(jù)是 WP_Error 的實(shí)例,那么 wpjam_send_json 直接輸出 errcode 和 errmsg JSON。如果沒有設(shè)置 errcode,則 wpjam_send_json 自動(dòng)加上 errcode=>0
安裝 WPJAM Basic 插件,你的 WordPress 就會(huì)有這個(gè)函數(shù)。
wp_send_json_success 和 wp_send_json_error
WordPress 還提供 wp_send_json_success 和 wp_send_json_error 兩個(gè)函數(shù):
wp_send_json_success( $data = null, $status_code = null ) wp_send_json_error( $data = null, $status_code = null )
wp_send_json_success 先輸出 success 為 true,然后把數(shù)據(jù) $data 放到 data 里面輸出。wp_send_json_error 則會(huì)判斷 $data 是否為 WP_Error 實(shí)例,如果是,則輸出 code 和 message 的數(shù)組。我們實(shí)現(xiàn)的 wpjam_send_json 已經(jīng)能夠自動(dòng)化處理這些錯(cuò)誤了。
wp_is_json_request
判斷當(dāng)前請(qǐng)求是不是 JSON 請(qǐng)求,或者返回 JSON 結(jié)果,這個(gè)函數(shù)沒有參數(shù),直接使用:
wp_is_json_request()
它通過判斷 $_SERVER['HTTP_ACCEPT'] 中含有 application/json,或者 $_SERVER['CONTENT_TYPE'] 等于 application/json。
wp_is_jsonp_request
判斷當(dāng)前請(qǐng)求是不是 JSONP 請(qǐng)求,或者返回 JSONP 結(jié)果,這個(gè)函數(shù)沒有參數(shù),直接使用:
wp_is_jsonp_request()
它首先判斷 $_GET['_jsonp'] ,是否存在,然后通過函數(shù) wp_check_jsonp_callback 判斷它的值是否合法。
wp_check_jsonp_callback
判斷 JSONP callback 是不是一個(gè)一個(gè)合法的 JavaScript callback 函數(shù):
wp_check_jsonp_callback( $callback )
合法的 JavaScript callback 函數(shù)只能數(shù)字加字符,以及英文點(diǎn)號(hào)。
看完了這篇文章,相信你對(duì)WordPress JSON處理相關(guān)函數(shù)的案例有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)站題目:WordPressJSON處理相關(guān)函數(shù)的案例-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://jinyejixie.com/article10/ccpcdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站策劃、移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站建設(shè)、網(wǎng)站改版、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容