引言
2018/7/2 陰
近日狀態(tài)不佳,有些掙脫地球躲起來的沖動(dòng),我需要休息休息。
社交、家庭情感,占據(jù)了很多精力。
已至無力吐槽。
回到正題
在php中最常用的發(fā)起http請(qǐng)求的莫過于curl,但是發(fā)現(xiàn)自己在工作中如果有需要用到curl的時(shí)候,都是直接從網(wǎng)上抄一段代碼拿來用,而且curl的參數(shù)實(shí)在是太多,看上去讓人感覺眼花繚亂,自己好像從來沒有認(rèn)真的去研究過每一個(gè)參數(shù)的用途,故在這篇博文中稍作整理,并配上相關(guān)的案例。
1、參數(shù)掃盲
- CURLOPT_RETURNTRANSFER
關(guān)于CURLOPT_RETURNTRANSFER,php文檔中的概念是:
將curl_exec()獲取的信息以文件流的形式返回,而不是直接輸出
關(guān)于curl_exec()的返回值,php文檔中的定義是:
成功時(shí)返回 TRUE, 或者在失敗時(shí)返回 FALSE。 然而,如果 CURLOPT_RETURNTRANSFER選項(xiàng)被設(shè)置,函數(shù)執(zhí)行成功時(shí)會(huì)返回執(zhí)行的結(jié)果,失敗時(shí)返回 FALSE 。
以一個(gè)實(shí)際案例來幫助大家理解:
<?php
//index.php
function curl_get($url){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
// curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch);
var_dump($output);
die();
curl_close($ch);
return $output;
}
curl_get("http://localhost/curl/d.php");
<?php
//d.php
exit(json_encode(
array(
'status' => 'ok',
'name' => 'ben'
)
));
當(dāng)index.php中的curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1)處于注釋狀態(tài)時(shí),訪問結(jié)果是:

當(dāng)index.php中的curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1)沒有處于注釋狀態(tài)時(shí),訪問結(jié)果是:

從兩次訪問結(jié)果對(duì)比來看,可以看出:
當(dāng)設(shè)置了CURLOPT_RETURNTRANSFER值時(shí),請(qǐng)求接口的結(jié)果不直接輸出,而是變成了curl_exec方法的返回值;
當(dāng)沒有設(shè)置CURLOPT_RETURNTRANSFER值時(shí),請(qǐng)求接口的結(jié)果直接輸出,curl_exec方法的返回值是true或者false;
- CURLOPT_FOLLOWLOCATION、CURLOPT_MAXREDIRS、CURLOPT_HEADER
各位是否請(qǐng)求過出現(xiàn)302或者是301跳轉(zhuǎn)的接口呢?比如下面的一個(gè)例子:
<?php
//c.php
header("location:http://localhost/curl/d.php");
exit();
<?php
//index.php
function curl_get($url){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch);
// var_dump($output);
// die();
curl_close($ch);
return $output;
}
// curl_get("http://localhost/curl/d.php");
var_dump(curl_get("http://localhost/curl/c.php"));
exit();
其中d.php文件內(nèi)容與上例相同,此處不再贅述。
這時(shí)訪問結(jié)果是:string ” (length=0)
發(fā)生了什么呢?我們可以加上curl_setopt($ch, CURLOPT_HEADER, 1)之后再次訪問,結(jié)果是:
HTTP/1.1 302 Found
Date: Tue, 24 Nov 2015 15:01:09 GMT
Server: Apache/2.4.9 (Win32) PHP/5.5.12
X-Powered-By: PHP/5.5.12
location: http://localhost/curl/d.php
Content-Length: 0
Content-Type: text/html
可以看到302跳轉(zhuǎn)之后,接口的返回值抓取不到了,這時(shí)怎么辦呢?可以使用CURLOPT_FOLLOWLOCATION,關(guān)于CURLOPT_FOLLOWLOCATION,文檔中的描述是:
啟用時(shí)會(huì)將服務(wù)器返回的”Location: “放在header中遞歸的返回給服務(wù)器,使用CURLOPT_MAXREDIRS可以限定遞歸返回的數(shù)量。
加上之后再次訪問,結(jié)果是:
{"status":"ok","name":"ben"}
這里有個(gè)待解決的疑問是CURLOPT_FOLLOWLOCATION究竟會(huì)遞歸幾次呢?筆者測試遞歸六次依舊能獲取接口返回值,難道默認(rèn)沒有遞歸限制會(huì)一直遞歸下去嗎?
CURLOPT_MAXREDIRS參數(shù)用來限定遞歸返回的數(shù)量,注意如果該值設(shè)定小于接口實(shí)際遞歸的次數(shù)的話,接口將會(huì)返回false。