您好,登錄后才能下訂單哦!
這篇文章給大家介紹利用PHP怎么對HTTP請求進(jìn)行獲取,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
1. 取得請求行:Method、URI、協(xié)議
可以從超級變量$_SERVER中獲得,三個變量的值如下:
$_SERVER['REQUEST_METHOD'].' '.$_SERVER['REQUEST_URI'].' '.$_SERVER['SERVER_PROTOCOL']."\r\n";
2. 取得所有Header
PHP有個內(nèi)置函數(shù)getallheader(),是apache_request_headers()函數(shù)的一個別名,可以將HTTP請求的所有Header以數(shù)組形式返回。但這個函數(shù)只能工作在Apache下,如果換了Nginx或者命令行,會直接報函數(shù)不存在的錯誤。
比較通用的方法是,從超級變量$_SERVER中提取出來,有關(guān)Header的鍵值都是“HTTP_”開頭的,可以根據(jù)此特點(diǎn)取得所有的Header。
具體代碼如下:
function get_all_headers() { $headers = array(); foreach($_SERVER as $key => $value) { if(substr($key, 0, 5) === 'HTTP_') { $key = substr($key, 5); $key = strtolower($key); $key = str_replace('_', ' ', $key); $key = ucwords($key); $key = str_replace(' ', '-', $key); $headers[$key] = $value; } } return $headers; }
3. 取得Body
官方提供了一種獲取請求Body的方法,即:
file_get_contents('php://input')
4. 最終完整代碼如下:
/** * 獲取HTTP請求原文 * @return string */ function get_http_raw() { $raw = ''; // (1) 請求行 $raw .= $_SERVER['REQUEST_METHOD'].' '.$_SERVER['REQUEST_URI'].' '.$_SERVER['SERVER_PROTOCOL']."\r\n"; // (2) 請求Headers foreach($_SERVER as $key => $value) { if(substr($key, 0, 5) === 'HTTP_') { $key = substr($key, 5); $key = str_replace('_', '-', $key); $raw .= $key.': '.$value."\r\n"; } } // (3) 空行 $raw .= "\r\n"; // (4) 請求Body $raw .= file_get_contents('php://input'); return $raw; }
關(guān)于利用PHP怎么對HTTP請求進(jìn)行獲取就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。