在WordPress中實現(xiàn)發(fā)送http請求的相關(guān)函數(shù)解析
在 PHP 中發(fā)送 Http 請求(GET / POST)有很多的方法,比如 file_get_contents() 函數(shù)、fopen() 函數(shù)或者 cURL 擴(kuò)展,但由于服務(wù)器的情況不同,所以不一定會兼容所有情況,這樣想要發(fā)送 Http 請求則需要經(jīng)過一系列的判斷,非常麻煩。
不過 WordPress 提供了一個 WP_Http 的類來幫你做好兼容性的判斷,你只需要調(diào)用里邊的函數(shù)就能完成發(fā)送 Http 請求。下面我就簡單的介紹一下這個類的常用函數(shù)。
發(fā)送 GET 請求
/** *使用 WP_Http 類發(fā)送簡單的 GET 請求 *http://www.endskin.com/wp_http/ */ $http = new WP_Http; $result = $http->request( 'http://www.endskin.com' );
上邊的代碼就把請求目標(biāo)的信息存儲到 $result 變量里了,$result 是一個數(shù)組,它有一下的鍵:
- headers:返回的 headers 信息,是一個數(shù)組
- body:目標(biāo)的內(nèi)容,和在瀏覽器里直接看是一樣的
- response:返回的代碼,如果請求成功會返回 array( 'code'=>200, 'message'=>'OK' )
- cookies:Cookie 信息,是一個數(shù)組
也就是說目標(biāo)的內(nèi)容就是 $result['body']
發(fā)送 POST 請求
如果需要發(fā)送 POST 請求就得用到 WP_Http->request() 的第二個參數(shù)了,下面看例子:
/** *使用 WP_Http 類發(fā)送簡單的 POST 請求 *http://www.endskin.com/wp_http/ */ $http = new WP_Http; $post = array( 'name' => '斌果', 'blog' => 'http://www.bgbk.org' ); $result = $http->request( 'http://www.endskin.com', array( 'method' => 'POST', 'body' => $post ) );
返回的$result 變量內(nèi)容請參考上邊的 GET 請求。
需要驗證的 POST 請求
假如你想在一些 RESTFul 的 API 提交一些信息,你首先需要進(jìn)行驗證,我們需要發(fā)送一個含有用戶名和密碼對的 base64 編碼的字符串給 API,詳細(xì)如下:
// You would edit the following:
$username = 'denishua'; // login
$password = '123456'; // password
$message = "I'm posting with the API";
// Now, the HTTP request:
$api_url = 'http://your.api.url/update.xml';
$body = array( 'status' => $message );
$headers = array( 'Authorization' => 'Basic '.base64_encode("$username:$password") );
$request = new WP_Http;
$result = $request->request( $api_url , array( 'method' => 'POST', 'body' => $body, 'headers' => $headers ) );
WordPress 加入 WP_Http 類之后,就放棄了 Snoopy 這個 PHP Class,所以建議大家給 WordPress 寫插件的時候,盡量使用 WP_Http 來做 HTTP 請求。
相關(guān)文章
PHP實現(xiàn)將標(biāo)點符號正則替換為空格的方法
這篇文章主要介紹了PHP實現(xiàn)將標(biāo)點符號正則替換為空格的方法,結(jié)合實例形式分析了php針對符號的正則匹配相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
CI框架源碼閱讀,系統(tǒng)常量文件constants.php的配置
CI框架源碼閱讀,系統(tǒng)常量文件constants.php的配置,需要的朋友可以參考一下2013-02-02
PHP錯誤Warning:mysql_query()解決方法
這篇文章主要介紹了PHP錯誤Warning:mysql_query()的解決方法,希望可以真正解決大家的問題,需要的朋友可以參考下2015-10-10
深入講解PHP的對象注入(Object Injection)
這篇文章主要介紹了PHP中對象注入的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03

