站長資訊網
        最全最豐富的資訊網站

        WordPress JSON 處理相關函數大全

        JSON處理是WordPress開發中的經常需要處理的一項工作,為此WordPress 定義了一堆JSON處理的函數,下面由WordPress教程欄目給大家做一下統一的介紹。

        WordPress JSON 處理相關函數大全

        wp_json_encode

        編碼成 JSON,并且進行一些完整性檢查。

        wp_json_encode( $data, $options = 0, $depth = 512 )

        簡單說下 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 對對象中的每個屬性進行清理。

        然后使用 json_encode 進行編碼,如果不成功,則使用 _wp_json_sanity_check 對數據進行完整性處理,最后再使用 json_encode 進行編碼。_wp_json_sanity_check 主要使用函數 _wp_json_convert_string 對數據進行深度 UTF-8 檢測和轉換。

        所以建議使用 wp_json_encode 對變量進行 JSON 編碼,它的可靠性更高。

        wpjam_json_encode

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

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 拍国产真实乱人偷精品| 野狼精品社区| 亚洲精品动漫免费二区| 2020最新久久久视精品爱| 国产午夜福利精品久久2021| 欧美精品色婷婷五月综合| 欧美+亚洲+精品+三区| 精品人无码一区二区三区| 亚洲精品网站在线观看不卡无广告| 99久久精品无码一区二区毛片| 91精品欧美综合在线观看| 日韩精品系列产品| 久久久亚洲精品蜜桃臀| 国产免费久久精品丫丫| 亚洲色图国产精品| 精品国精品国产| japanese乱人伦精品| 久久香综合精品久久伊人| 亚洲精品乱码久久久久久按摩| 日本精品一区二区三区在线视频 | 99久久精品免费看国产一区二区三区 | 中文字幕在线精品视频入口一区| 九九久久精品国产| 精品国产91久久久久久久a | 国产精品白丝AV网站| 精品亚洲A∨无码一区二区三区 | 亚洲欧美精品综合中文字幕| 久久露脸国产精品| 免费精品精品国产欧美在线欧美高清免费一级在线 | 亚洲午夜精品久久久久久app| 欧美在线精品永久免费播放| 青草青草久热精品视频在线观看| 久久久久久久久久久免费精品| 国精品产露脸自拍| 精品欧美激情在线看| 欧美精品亚洲精品日韩精品 | 国产福利视精品永久免费| 国产成人精品久久二区二区| 久久精品国产福利国产秒| 国产VA免费精品高清在线| 国产这里有精品|