3 回答
TA贡献1820条经验 获得超2个赞
小 PHP/CURL 测试脚本:
<?php
echo 'PHP version: ' . phpversion() . PHP_EOL;
echo 'cURL version: ' . curl_version()['version'] . PHP_EOL;
$ch = curl_init('https://www.howsmyssl.com/a/check');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
//curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_0); // TLS 1.0
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_1); // TLS 1.1
//curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_2); // TLS 1.2 or 1.3
$data = curl_exec($ch);
curl_close($ch);
$json = json_decode($data);
echo ($data ? $json->tls_version : 'curl request failed') . PHP_EOL;
TA贡献1848条经验 获得超2个赞
为了回答我自己的问题,https ://www.php.net/function.curl-setopt 上的文档已过时。cURL 7.54 更改了 CURL_SSLVERSION_ 宏的行为,这些现在设置了连接可接受的最低 TLS 版本。它还引入了 CURL_SSLVERSION_MAX_ 宏,用于设置尝试的最大 TLS 版本。在 PHP 文档更新之前,请参阅https://curl.haxx.se/libcurl/c/CURLOPT_SSLVERSION.html。
因此,将连接限制为 TLS v1.1 的工作方式如下:
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.paypal.com/v1/oauth2/token');
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_MAX_TLSv1_1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($ch);
TA贡献1802条经验 获得超4个赞
鉴于 TLS v1.1 或更高版本(在 7.34.0 中添加)非常清楚以及“可以使用 CURL_SSLVERSION_MAX_ 宏之一设置最大 TLS 版本”,“请求的 TLS v1.1”是错误的
- 3 回答
- 0 关注
- 486 浏览
添加回答
举报