php cURL Unknown SSL protocol error in connection to vendor.tanga.com:443
程序员文章站
2024-03-14 13:50:16
...
最近在对接国外的Tanga电商平台,代码在本地已经开发完毕,本地测试OK,已经把店铺的订单导入到本地测试环境了。心情满满的高兴,但是没想到部署到生产环境,就出现问题了。
环境对比:
服务器环境:Windows Server 2003 PHP 5.2.17 / OpenSSL 0.9.8
本地环境:Window 7 PHP 5.4.45 / OopenSSL 1.0.2j
接口调用的公共方法:
注意 CURLOPT_SSLVERSION 设置为1
public function curlGet($url,$parameters = array(),$header = array()){
if($parameters){
$url .= '?'.http_build_query($parameters);
}
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSLVERSION, 1);
if($header) curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION,1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 300);
curl_setopt($ch, CURLOPT_TIMEOUT, 100);
$result = curl_exec($ch);
$error = curl_error($ch);
return json_decode($result,true);
}
服务器访问API对接方法,提示错误:
Unknown SSL protocol error in connection to vendor.tanga.com:443
首先怀疑是产生服务器SSL协议版本过低,把本地环境切换到 PHP 5.2.17,果然出现与服务器一样的错误。
升级服务器版本到 PHP 5.4.45后,配置计划任务调用API方法,运行计划任务发现问题依然存在。
但是在浏览器直接运行API文件却调用无异常出现。
分析:浏览器调用和计划任务调用可能运行的环境不一样
方案:计划任务运行时通过cURL HTTP方式运行API文件(https://127.0.0.1/testapi.php)
结果:计划任务运行正常。
$ch = curl_init();
curl_setopt($ch, CURLOPT_POST, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
curl_setopt($ch, CURLOPT_URL,'http://localhost/testapi.php');
curl_exec($ch);
curl_close($ch);
这里通过 cURL调用 testapi.php文件,是通过HTTP协议调用,而不是通过计划任务 php 命令直接调用testapi.php文件,这两者可能有一些区别,可能只SSL证书的问题?
上一篇: php 事务回滚