PHP獲取HTTP body內容
PHP 獲取Http body的內容
有時候我們獲取資料時需要根據Header中的格式來解析,比如上傳一個json而不是一個文字。這裡用到了 php輸入|輸出流 的概念。
PHP 提供了一些雜項輸入/輸出(IO)流,允許訪問 PHP 的輸入輸出流、標準輸入輸出和錯誤描述符, 記憶體中、磁碟備份的臨時檔案流以及可以操作其他讀取寫入檔案資源的過濾器。
本文涉及到了了,php://input,詳盡內容請參閱官網:點選檢視官網
php://input 是個可以訪問請求的原始資料的只讀流。 POST 請求的情況下,最好使用 php://input
來代替 $HTTP_RAW_POST_DATA
,因為它不依賴於特定的 php.ini 指令。 而且,這樣的情況下 $HTTP_RAW_POST_DATA 預設沒有填充, 比啟用 always_populate_raw_post_data
enctype="multipart/form-data"
的時候 php://input
是無效的。
模擬程式碼
// server.php
switch($_SERVER['CONTENT_TYPE']){
case 'application/json':
// 這裡通過輸入端來獲取資料
$body = file_get_contents('php://input');
echo '這是一個json:', $body;
break;
// ...
}
// client_web.php, 注意這裡使用了 axios
// ...
service = axios.create({
baseURL: 'mydomain',
validateStatus:function(status){
if(500 >= status) alert('server fails');
}
});
// 發一個請求
service.post(url, {
// ...
headers: {'Content-Type':'application/json'},
data:'{"code":100}'
// ...
});
// 全域性設定也沒問題
service.interceptors.request.use(function (config){
// 這裡設定請求頭
config.headers['Content-Type'] = 'application/json';
return config;
}, function(err){});
引申閱讀
以下為官方文件小抄
PHP 輸入|輸出流分為: php://stdin, php://stdout 和 php://stderr
php://stdin
、php://stdout
和php://stderr
允許直接訪問 PHP 程序相應的輸入或者輸出流。 資料流引用了複製的檔案描述符,所以如果你開啟php://stdin
並在之後關了它, 僅是關閉了複製品,真正被引用的 STDIN 並不受影響。 注意 PHP 在這方面的行為有很多 BUG 直到 PHP 5.2.1。 推薦你簡單使用常量 STDIN、 STDOUT 和 STDERR 來代替手工開啟這些封裝器。
其中php://stdin
是隻讀的,php://stdout
和php://stderr
是隻寫的。
php://output
php://output
是一個只寫的資料流, 允許你以 print 和 echo 一樣的方式 寫入到輸出緩衝區。
php://fd
php://fd
允許直接訪問指定的檔案描述符。 例如 php://fd/3 引用了檔案描述符 3。
php://memory 和 php://temp
php://memory
和 php://temp
是一個類似檔案 包裝器的資料流,允許讀寫臨時資料。 兩者的唯一區別是 php://memory
總是把資料儲存在記憶體中, 而 php://temp
會在記憶體量達到預定義的限制後(預設是 2MB)存入臨時檔案中。 臨時檔案位置的決定和 sys_get_temp_dir()
的方式一致。
php://temp 的記憶體限制可通過新增 /maxmemory:NN 來控制,NN 是以位元組為單位、保留在記憶體的最大資料量,超過則使用臨時檔案。
php://filter
php://filter
是一種元封裝器, 設計用於資料流開啟時的篩選過濾應用。 這對於一體式(all-in-one)的檔案函式非常有用,類似 readfile()
、 file()
和 file_get_contents()
, 在資料流內容讀取之前沒有機會應用其他過濾器。
php://filter
目標使用以下的引數作為它路徑的一部分。 複合過濾鏈能夠在一個路徑上指定。詳細使用這些引數可以參考具體範例。