首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >cURL不支持的SSL协议

cURL不支持的SSL协议
EN

Stack Overflow用户
提问于 2016-01-21 01:55:09
回答 4查看 3.6K关注 0票数 1

在我的PHP5.4.48应用程序中运行它时,我有一个cURL请求失败。有趣的是,当它直接通过控制台或邮递员运行时,它会正确地执行。

我所连接的API需要一个TLSv1.2连接,这是我在我的应用程序中指定的。

下面是我的PHP应用程序中的简单请求:

代码语言:javascript
复制
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://dev-dataconnect.givex.com:50104');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POSTFIELDS,$payload);

curl_setopt($ch, CURLOPT_POST, 1 );
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: text/plain;charset=UTF-8')); 
curl_setopt($ch, CURLOPT_SSLVERSION, 6);
// curl_setopt($ch, CURLOPT_SSLVERSION, 'CURL_SSLVERSION_TLSv1_2'); // specifying value by name was of no help
curl_setopt($ch, CURLOPT_SSL_CIPHER_LIST, 'TLS_RSA_WITH_AES_256_CBC_SHA256');

curl_exec($ch);

一个原始的cURL请求应该是这样的(请注意,这个请求在控制台内成功触发)

代码语言:javascript
复制
curl 'https://dev-dataconnect.givex.com:50104/' -H 'Accept-Encoding: gzip, deflate' -H 'Accept-Language: en-US,en;q=0.8' -H 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.111 Safari/537.36' -H 'Content-Type: text/plain;charset=UTF-8' -H 'Accept: */*' -H 'Cache-Control: no-cache' -H 'Connection: keep-alive' --data-binary $'{"method":"dc_909","id":"confidential","jsonrpc":"2.0","params":["en","confidential","29530","confidential"]}\n' --compressed

还要注意,我不需要为成功的握手指定SSL版本

这是运行curl -v 'https://dev-dataconnect.givex.com:50104/‘的打印输出

代码语言:javascript
复制
* Connected to dev-dataconnect.givex.com (72.15.49.106) port 50104 (#0)
* TLS 1.2 connection using TLS_RSA_WITH_AES_256_CBC_SHA256
* Server certificate: *.givex.com
* Server certificate: Trustwave Organization Validation SHA256 CA, Level 1
* Server certificate: SecureTrust CA
> GET / HTTP/1.1
> Host: dev-dataconnect.givex.com:50104
> User-Agent: curl/7.43.0
> Accept: */*

我在跑

代码语言:javascript
复制
 - PHP 5.4.48
 - curl 7.43.0 (within both my MAMP and my Mac environments)
 - OpenSSL/0.9.8zd (within both my MAMP and my Mac environments)

从上周起,我就一直在排除这个问题。有什么主意吗??

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2016-01-21 05:57:39

  • OpenSSL/0.9.8zd (在我的MAMP和Mac环境中)

..。

我所连接的API需要一个TLSv1.2连接,这是我在我的应用程序中指定的。

OpenSSL 0.9.8不支持TLS1.2。只在OpenSSL 1.0.1中添加了支持。

票数 2
EN

Stack Overflow用户

发布于 2021-06-09 14:51:05

我今天无意中发现了这个错误,但却发现了另一种不同的味道。一个老站点正在使用TLSv1.0,自从升级到Ubuntu20.04之后,我们无法访问它。解决办法是

代码语言:javascript
复制
 curl_setopt($ch, CURLOPT_SSL_CIPHER_LIST, 'DEFAULT@SECLEVEL=1');
票数 2
EN

Stack Overflow用户

发布于 2016-08-09 22:04:57

以下代码适用于我:

代码语言:javascript
复制
<?php
$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_PORT => "50104",
  CURLOPT_URL => "https://dev-dataconnect.givex.com:50104/",
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => "",
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 30,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => "POST",
  CURLOPT_POSTFIELDS => "{\"method\":\"dc_909\",\"id\":\"confidential\",\"jsonrpc\":\"2.0\",\"params\":[\"en\",\"confidential\",\"29530\",\"confidential\"]}",
  CURLOPT_HTTPHEADER => array(
    "accept: */*",
    "accept-encoding: gzip, deflate",
    "accept-language: en-US,en;q=0.8",
    "cache-control: no-cache",
    "connection: keep-alive",
    "content-type: text/plain;charset=UTF-8",
    "user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.111 Safari/537.36"
  ),
));

$response = curl_exec($curl);
$err = curl_error($curl);

curl_close($curl);

if ($err) {
    echo "cURL Error #:" . $err;
} else {
    echo $response;
}
?>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34914065

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档