OpenSSL SSL_read: SSL_ERROR_SYSCALL, errno 104

2022-08-30 21:19:58

我通过curl在基于ssl means(https)的api上放置订单数据,但它返回OpenSSL SSL_read:SSL_ERROR_SYSCALL,errno 104消息。

以下是我的测试代码,根据客户端所需的json:

$apiKey = "xxxxxx-xxxxxx-xxxxx-xxxxxx-xxxxxx";
$privatekey = "xxxxxx-xxxxxx-xxxxx-xxxxxx-xxxxxx";
$timestamp = date('Y-m-d H:i:s'); // (for example: 2016-07-19 14:05:55)

$signature = hash_hmac('sha1', $timestamp, $apiKey);
$signature = hash_hmac('sha1', $privatekey, $signature);

$postURL = "https://www.compu-cover.com/intelligent-rewards/orders/?OrderNo=123";

$orderInfo['Order'] = array(
        "apiKey" => $apiKey,
        "privatekey" => $privatekey,
        "Signature" => $signature,
        "Timestamp" => $timestamp,
        "Firstname" => "Ajay",
        "Surname" => "Sharma",
        "EmailAddress" => "ajay@yopmail.com",
        "DaytimeTel" => "0141798526",
        "EveningTel" => "0141798526",
        "MobileTel" => "9887654321",
        "Address1" => "A-5",
        "Address2" => "Jhalana",
        "Address3" => "Jaipur",
        "Address4" => "Rajasthan",
        "County" => "India",
        "Postcode" => "302019", 
        "Cover" => "ADTBL",
        "Scheme" => 2, 
        "Premium" => 5,
        "EquipmentQty" => 1,
        "EquipmentType1" => "Smartphone",
        "EquipmentMake1" => "Moto",
        "EquipmentModel1" => "Moto G",
        "EquipmentPrice1" => 100
    );

$params = json_encode($orderInfo);

$session = curl_init($postURL);

curl_setopt($session, CURLOPT_POST, true);
curl_setopt($session, CURLOPT_POSTFIELDS, $params);
curl_setopt($session, CURLOPT_HEADER, true);
curl_setopt($session, CURLOPT_SSL_VERIFYPEER, true); 

$response = curl_exec($session);

if (FALSE === $response) {
    var_dump(curl_error($session));
    var_dump(curl_errno($session));
}

curl_close($session);
$response = json_decode($response);

var_dump($response);

如何找到失败的原因?失败的原因可能是什么?请提供您的建议。


答案 1

在标准 C 库中,该变量包含最近一次系统调用出错的代码。值 104 定义为“对等方重置连接”。errnoECONNRESET

该错误只是意味着另一方挂断了您的电话,而没有完成正常的HTTPS协议并返回任何回报......可能由于各种原因,可能是网络问题,或服务器端程序崩溃,或者另一端根本不喜欢你所做的。它与OpenSSL根本不相关,要知道是什么原因造成的,你需要访问服务器日志。


答案 2

您可能有很多原因可能会得到这个。

对我来说,我得到这个是因为我使用的是curl,而我正在访问的网站不喜欢使用curl。我用以下方法修复了这个问题:

curl -A "Mozilla Chrome Safari" someserver.com/somepage.html

这告诉curl对服务器说,“嘿,我是一个浏览器”。您可以使用自己喜欢的浏览器来获取更好的更新字符串,转到浏览器开发人员控制台,通常在“网络”下,您可以看到各个请求项,在那里您可以获取当前浏览器作为“用户代理”发送的字符串。

网站这样做的原因是您的典型客户不使用curl。最好的情况是卷曲将是一个机器人耗尽服务器资源,最坏的情况是它是一个邪恶的黑客。


推荐