PHP實現(xiàn)取得HTTP請求的原文
本文實例講述了PHP實現(xiàn)取得HTTP請求的原文的方法,具體步驟如下:
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ù)此特點取得所有的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;
}
感興趣的讀者可以調(diào)試一下本文所述實例,以加深理解。相信對大家的PHP程序設(shè)計有一定的幫助作用。
- PHP獲取http請求的頭信息實現(xiàn)步驟
- php之curl實現(xiàn)http與https請求的方法
- php中調(diào)用其他系統(tǒng)http接口的方法說明
- PHP 使用header函數(shù)設(shè)置HTTP頭的示例解析 表頭
- php抓取https的內(nèi)容的代碼
- php curl 獲取https請求的2種方法
- 在PHP中實現(xiàn)使用Guzzle執(zhí)行POST和GET請求
- 在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼
- 使用Zttp簡化Guzzle 調(diào)用
- PHP的HTTP客戶端Guzzle簡單使用方法分析
相關(guān)文章
PHP面向?qū)ο蟪绦蛟O(shè)計子類擴展父類(子類重新載入父類)操作詳解
這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計子類擴展父類(子類重新載入父類)操作,涉及php面向?qū)ο蠓椒ㄖ貙懪c擴展相關(guān)操作技巧,需要的朋友可以參考下2019-06-06
php獲取mysql數(shù)據(jù)庫中的所有表名的代碼
如何用PHP獲取MYSQL數(shù)據(jù)庫的所有表名?記得在mysql命令行下面有條命令SHOW TABLES是顯示mysql數(shù)據(jù)庫里面所有數(shù)據(jù)表的,那么就用這條命令來遍歷數(shù)據(jù)表名吧2011-04-04

