首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ByPass SSL证书验证的Artax

ByPass SSL证书验证的Artax
EN

Stack Overflow用户
提问于 2014-05-19 07:54:35
回答 2查看 454关注 0票数 0

当向具有无效SSL证书( Cloudflare必须重新颁发证书)的服务器发出POST请求时,Artax会返回以下错误:

routines:SSL3_GET_SERVER_CERTIFICATE:certificate操作失败,代码1。OpenSSL错误消息:错误:14090086: SSL OpenSSL验证失败

我试着用

代码语言:javascript
复制
$client->setOption('tlsOptions', [
    'verify_peer' => FALSE,
]);

代码语言:javascript
复制
$request->setOption('tlsOptions', [
    'verify_peer' => FALSE,
]);

但是,在这两种情况下,都会引发错误。

有人能说明正确的方法,以禁用与Artax同行验证吗?

更新

我都试过了:

代码语言:javascript
复制
$client->setAllOptions([
    'tlsOptions' => [
        'verify_peer' => FALSE,
        'allow_self_signed' => TRUE,
    ],
]);

代码语言:javascript
复制
$client->setOption('tlsOptions', [
    'verify_peer' => FALSE,
    'allow_self_signed' => TRUE,
]);

两人都给了我400的答复(不好的要求)。

代码语言:javascript
复制
[status:Artax\Response:private] => 400
        [reason:Artax\Response:private] => Bad Request
        [protocol:Artax\Message:private] => 1.1
        [headers:Artax\Message:private] => Array
            (
                [Date] => Array
                    (
                        [0] => Mon, 19 May 2014 09:50:19 GMT
                    )

                [Server] => Array
                    (
                        [0] => Apache/2.4.9 (Ubuntu)
                    )

                [Content-Length] => Array
                    (
                        [0] => 303
                    )

                [Connection] => Array
                    (
                        [0] => close
                    )

                [Content-Type] => Array
                    (
                        [0] => text/html; charset=iso-8859-1
                    )

            )

        [headerCaseMap:Artax\Message:private] => Array
            (
                [DATE] => Date
                [SERVER] => Server
                [CONTENT-LENGTH] => Content-Length
                [CONNECTION] => Connection
                [CONTENT-TYPE] => Content-Type
            )
EN

回答 2

Stack Overflow用户

发布于 2014-05-19 08:07:14

也许允许自我签名会有效果:

代码语言:javascript
复制
$client->setOption('tlsOptions', [
    'verify_peer' => FALSE,
    'allow_self_signed' => TRUE,
    ]);
票数 0
EN

Stack Overflow用户

发布于 2015-09-13 13:59:49

对于当前的master分支,以下内容将绕过验证:

代码语言:javascript
复制
$client->setOption(Amp\Artax\Client::OP_CRYPTO, [
    "verify_peer" => false,
    "verify_peer_name" => false
]);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23732447

复制
相关文章

相似问题

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