如何获取有关已发送的 PHP curl 请求的信息

2022-08-30 09:05:33

我正在尝试调试对Web服务“getToken”端点的curl请求。

我不是100%确信URL和身份验证信息被正确写入卷曲句柄。

我正在尝试用于捕获发送的请求,但它没有给我太多信息。有没有办法更深入地诊断实际的 curl 请求的外观?curl_getinfo($ch, CURLINFO_HEADER_OUT);

代码如下:

$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD, "$username:$password");       
curl_setopt($ch, CURLOPT_HEADER, 1); // just getting header to see if we got an auth token
curl_setopt($ch, CURLOPT_FILE, $fh);
curl_setopt($ch, CURLOPT_NOBODY, 1); 
curl_setopt($ch, CURLINFO_HEADER_OUT, 1); // capture the header info
curl_setopt($ch, CURLOPT_VERBOSE, 1); // turn verbose on    
// execute the curl request 

$rh = fopen("request.txt", "w"); // open request file handle
$verbose = fopen('php://temp', 'rw+');
curl_setopt($ch, CURLOPT_STDERR, $verbose);

curl_exec($ch); // execute request

$sent_request = curl_getinfo($ch, CURLINFO_HEADER_OUT);
fwrite($rh, $sent_request); // save the request info
fclose($rh);
!rewind($verbose);
$verboseLog = stream_get_contents($verbose);

echo "Verbose information:\n<pre>", htmlspecialchars($verboseLog), "</pre>\n";

到目前为止,这一切都有效,但每次都会返回401 - API管理员向我保证我拥有的用户名/通行证是正确的。

我想知道我是否以某种方式弄错了URL值,或者没有发送正确的用户名/通行证,但此信息未打印在保存的请求数据中:

HEAD /export/auth HTTP/1.1
Authorization: Basic Y2FpcmRzdW5mYTpENWlAaVM4cw==
Host: webservices.mycompany.com
Accept: */*

您可以看到没有记录用户名/通行证(我假设是为了安全起见)。我认为端点URL是值加上值的开头,所以?hostHEADwebservices.mycompany.com/export/auth

“详细信息”语句不打印任何内容。不知道为什么在这一点上!

感谢您的帮助。

编辑:从Php添加了详细模式 - 调试卷曲感谢评论者immuratin


答案 1

如果设置为 ,则传出标头在 键下由 返回的数组中可用:CURLINFO_HEADER_OUTtruecurl_getinfo()request_header

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "http://foo.com/bar");
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD, "someusername:secretpassword");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLINFO_HEADER_OUT, true);

curl_exec($ch);

$info = curl_getinfo($ch);
print_r($info['request_header']);

这将打印:

GET /bar HTTP/1.1
Authorization: Basic c29tZXVzZXJuYW1lOnNlY3JldHBhc3N3b3Jk
Host: foo.com
Accept: */*

请注意,身份验证详细信息采用 base64 编码:

echo base64_decode('c29tZXVzZXJuYW1lOnNlY3JldHBhc3N3b3Jk');
// prints: someusername:secretpassword

另请注意,用户名和密码需要进行百分比编码,以转义它们可能包含的任何 URL 保留字符(、、、等):/?&:

curl_setopt($ch, CURLOPT_USERPWD, urlencode($username).':'.urlencode($password));

答案 2

您还可以使用像Charles这样的代理工具,通过将代理详细信息传递到您的方法来捕获传出请求标头,数据等。CURLOPT_PROXYcurl_setopt_array

例如:

$proxy = '127.0.0.1:8888';
$opt = array (
    CURLOPT_URL => "http://www.example.com",
    CURLOPT_PROXY => $proxy,
    CURLOPT_POST => true,
    CURLOPT_VERBOSE => true,
    );

$ch = curl_init();
curl_setopt_array($ch, $opt);
curl_exec($ch);
curl_close($ch);

推荐