PHP CURL_ERRNO 77

Posted 凌雨尘

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP CURL_ERRNO 77相关的知识,希望对你有一定的参考价值。

项目中碰到curl https偶尔出现false,错误码77,可以尝试下面两种解决方法:

1、确认安装机器ca-certificates,重启php。设置curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0):阻止对证书的合法性的检查

$ service php-fpm restart


2、centos默认安装curl ssl_version:NSS,需要更改为openssl

 
libcurl错误代码

名称
libcurl-errors - libcurl中的错误代码

描述
此手册页包含libcurl中的大多数(如果不是全部)可用错误代码。它们为什么会发生,也可能包括解决问题的方法。

CURLcode
几乎所有“简单”接口函数都返回CURLcode错误代码。无论如何,使用curl_easy_setopt选项CURLOPT_ERRORBUFFER是一个好主意,因为它将为您提供一个人类可读的错误字符串,可以提供有关错误原因的更多详细信息,而不仅仅是错误代码。可以调用curl_easy_strerror从给定的CURLcode编号中获取错误字符串。

CURLcode是以下之一:

CURLE_OK(0)

一切都很好。像往常一样继续。

CURLE_UNSUPPORTED_PROTOCOL(1)

您传递给libcurl的URL使用了此libcurl不支持的协议。支持可能是您没有使用的编译时选项,它可能是拼写错误的协议字符串,或者只是libcurl没有代码的协议。

CURLE_FAILED_INIT(2)

很早的初始化代码失败了。这可能是内部错误或问题,或者是在初始时无法完成某些基本操作的资源问题。

CURLE_URL_MALFORMAT(3)

URL格式不正确。

CURLE_NOT_BUILT_IN(4)

由于构建时决定,未在此libcurl中找到所请求的功能,协议或选项。这意味着在构建libcurl时未启用或显式禁用某个功能或选项,并且为了使其正常运行,您必须获得重建的libcurl。

CURLE_COULDNT_RESOLVE_PROXY(5)

无法解析代理。无法解析给定的代理主机。

CURLE_COULDNT_RESOLVE_HOST(6)

无法解析主机。给定的远程主机未解析。

CURLE_COULDNT_CONNECT(7)

无法连接()到主机或代理。

CURLE_FTP_WEIRD_SERVER_REPLY(8)

服务器发送的数据libcurl无法解析。此错误代码不仅用于FTP,而且自7.51.0起别名为CURLE_WEIRD_SERVER_REPLY。

CURLE_REMOTE_ACCESS_DENIED(9)

我们被拒绝访问URL中给出的资源。对于FTP,尝试更改到远程目录时会发生这种情况。

CURLE_FTP_ACCEPT_FAILED(10)

在使用活动FTP会话时等待服务器连接回来时,通过控制连接或类似方式发送错误代码。

CURLE_FTP_WEIRD_PASS_REPLY(11)

在将FTP密码发送到服务器之后,libcurl希望得到适当的回复。此错误代码表示返回了意外的代码。

CURLE_FTP_ACCEPT_TIMEOUT(12)

在等待服务器连接的活动FTP会话期间,CURLOPT_ACCEPTTIMEOUT_MS(或内部默认值)超时已到期。

CURLE_FTP_WEIRD_PASV_REPLY(13)

libcurl无法从服务器获得合理的结果作为对PASV或EPSV命令的响应。服务器存在缺陷。

CURLE_FTP_WEIRD_227_FORMAT(14)

FTP服务器返回227行作为对PASV命令的响应。如果libcurl无法解析该行,则返回此返回码。

CURLE_FTP_CANT_GET_HOST(15)

查找用于新连接的主机的内部故障。

CURLE_HTTP2(16)

在HTTP2框架层中检测到问题。这有些通用,可能是几个问题中的一个,请参阅错误缓冲区了解详细信息。

CURLE_FTP_COULDNT_SET_TYPE(17)

尝试将传输模式设置为二进制或ASCII时收到错误。

CURLE_PARTIAL_FILE(18)

文件传输比预期的更短或更长。当服务器首次报告预期的传输大小,然后传递与先前给定大小不匹配的数据时,会发生这种情况。

CURLE_FTP_COULDNT_RETR_FILE(19)

这可能是对‘RETR‘命令的奇怪回复,也可能是零字节传输完成。

CURLE_QUOTE_ERROR(21)

向远程服务器发送自定义“QUOTE”命令时,其中一个命令返回的错误代码为400或更高(对于FTP)或以其他方式表示命令未成功完成。

CURLE_HTTP_RETURNED_ERROR(22)

如果CURLOPT_FAILONERROR设置为TRUE且HTTP服务器返回> = 400的错误代码,则返回此值。

CURLE_WRITE_ERROR(23)

将接收的数据写入本地文件时发生错误,或者从写回调将错误返回到libcurl。

CURLE_UPLOAD_FAILED(25)

启动上传失败。对于FTP,服务器通常拒绝STOR命令。错误缓冲区通常包含服务器对此的解释。

CURLE_READ_ERROR(26)

读取本地文件或读取回调返回的错误时出现问题。

CURLE_OUT_OF_MEMORY(27)

内存分配请求失败。这是严重的坏事,如果发生这种情况,事情就会严重搞乱。

CURLE_OPERATION_TIMEDOUT(28)

操作超时。根据条件达到规定的超时时间。

CURLE_FTP_PORT_FAILED(30)

FTP PORT命令返回错误。当您没有为libcurl指定足够好的地址时,这通常会发生。请参见CURLOPT_FTPPORT。

CURLE_FTP_COULDNT_USE_REST(31)

FTP REST命令返回错误。如果服务器是理智的,这应该永远不会发生。

CURLE_RANGE_ERROR(33)

服务器不支持或接受范围请求。

CURLE_HTTP_POST_ERROR(34)

这是一个奇怪的错误,主要是由于内部混乱造成的。

CURLE_SSL_CONNECT_ERROR(35)

SSL / TLS握手中出现问题。你真的想要错误缓冲区并在那里阅读消息,因为它会稍微查明问题。可以是证书(文件格式,路径,权限),密码等。

CURLE_BAD_DOWNLOAD_RESUME(36)

无法恢复下载,因为指定的偏移量超出了文件边界。

CURLE_FILE_COULDNT_READ_FILE(37)

无法打开以FILE://指定的文件。很可能是因为文件路径无法识别现有文件。你检查过文件权限了吗?

CURLE_LDAP_CANNOT_BIND(38)

LDAP无法绑定。LDAP绑定操作失败。

CURLE_LDAP_SEARCH_FAILED(39)

LDAP搜索失败。

CURLE_FUNCTION_NOT_FOUND(41)

找不到功能。找不到所需的zlib函数。

CURLE_ABORTED_BY_CALLBACK(42)

被回调中止。回调“abort”返回libcurl。

CURLE_BAD_FUNCTION_ARGUMENT(43)

内部错误。使用错误参数调用函数。

CURLE_INTERFACE_FAILED(45)

接口错误。无法使用指定的传出接口。使用CURLOPT_INTERFACE设置用于传出连接的源IP地址的接口。

CURLE_TOO_MANY_REDIRECTS(47)

重定向太多。在执行重定向后,libcurl会达到最大值。使用CURLOPT_MAXREDIRS设置限制。

CURLE_UNKNOWN_OPTION(48)

传递给libcurl的选项无法识别/已知。请参阅相应的文档。这很可能是使用libcurl的程序中的一个问题。错误缓冲区可能包含有关其所涉及的确切选项的更具体信息。

CURLE_TELNET_OPTION_SYNTAX(49)

telnet选项字符串是非法格式化的。

CURLE_GOT_NOTHING(52)

没有从服务器返回任何内容,在这种情况下,什么都没有被认为是错误。

CURLE_SSL_ENGINE_NOTFOUND(53)

找不到指定的加密引擎。

CURLE_SSL_ENGINE_SETFAILED(54)

将所选SSL加密引擎设置为默认值失败!

CURLE_SEND_ERROR(55)

发送网络数据失败。

CURLE_RECV_ERROR(56)

接收网络数据失败。

CURLE_SSL_CERTPROBLEM(58)

本地客户端证书的问题。

CURLE_SSL_CIPHER(59)

无法使用指定的密码。

CURLE_PEER_FAILED_VERIFICATION(60)

远程服务器的SSL证书或SSH md5指纹被认为不正常。自7.62.0起,此错误代码已与CURLE_SSL_CACERT统一。它之前的价值是51。

CURLE_BAD_CONTENT_ENCODING(61)

无法识别的传输编码。

CURLE_LDAP_INVALID_URL(62)

无效的LDAP URL。

CURLE_FILESIZE_EXCEEDED(63)

超出最大文件大小。

CURLE_USE_SSL_FAILED(64)

请求的FTP SSL级别失败。

CURLE_SEND_FAIL_REWIND(65)

在执行发送操作时,curl必须回滚数据以重新传输,但是倒带操作失败。

CURLE_SSL_ENGINE_INITFAILED(66)

启动SSL引擎失败。

CURLE_LOGIN_DENIED(67)

远程服务器拒绝curl登录(在7.13.1中添加)

CURLE_TFTP_NOTFOUND(68)

在TFTP服务器上找不到文件。

CURLE_TFTP_PERM(69)

TFTP服务器上的权限问题。

CURLE_REMOTE_DISK_FULL(70)

服务器上的磁盘空间不足。

CURLE_TFTP_ILLEGAL(71)

非法的TFTP操作。

CURLE_TFTP_UNKNOWNID(72)

未知的TFTP传输ID。

CURLE_REMOTE_FILE_EXISTS(73)

文件已存在且不会被覆盖。

CURLE_TFTP_NOSUCHUSER(74)

正常运行的TFTP服务器永远不应该返回此错误。

CURLE_CONV_FAILED(75)

字符转换失败。

CURLE_CONV_REQD(76)

呼叫者必须注册转换回调。

CURLE_SSL_CACERT_BADFILE(77)

读取SSL CA证书时出现问题(路径?访问权限?)

CURLE_REMOTE_FILE_NOT_FOUND(78)

URL中引用的资源不存在。

CURLE_SSH(79)

SSH会话期间发生了未指定的错误。

CURLE_SSL_SHUTDOWN_FAILED(80)

无法关闭SSL连接。

CURLE_AGAIN(81)

套接字尚未准备好发送/接收等待,直到它准备好再试一次。此返回码仅从curl_easy_recv和curl_easy_send返回(在7.18.2中添加)

CURLE_SSL_CRL_BADFILE(82)

无法加载CRL文件(在7.19.0中添加)

CURLE_SSL_ISSUER_ERROR(83)

发行人检查失败(在7.19.0中添加)

CURLE_FTP_PRET_FAILED(84)

FTP服务器根本不理解PRET命令或不支持给定的参数。使用CURLOPT_CUSTOMREQUEST时要小心,在PASV之前也会使用PRET CMD发送自定义LIST命令。(在7.20.0中添加)

CURLE_RTSP_CSEQ_ERROR(85)

RTSP CSeq号码不匹配。

CURLE_RTSP_SESSION_ERROR(86)

RTSP会话标识符不匹配。

CURLE_FTP_BAD_FILE_LIST(87)

无法解析FTP文件列表(在FTP通配符下载期间)。

CURLE_CHUNK_FAILED(88)

块回调报告错误。

CURLE_NO_CONNECTION_AVAILABLE(89)

(仅供内部使用,libcurl永远不会返回)没有可用的连接,会话将排队。(在7.30.0中添加)

CURLE_SSL_PINNEDPUBKEYNOTMATCH(90)

无法匹配CURLOPT_PINNEDPUBLICKEY指定的固定密钥。

CURLE_SSL_INVALIDCERTSTATUS(91)

当询问CURLOPT_SSL_VERIFYSTATUS时,状态返回失败。

CURLE_HTTP2_STREAM(92)

HTTP / 2成帧层中的流错误。

CURLE_RECURSIVE_API_CALL(93)

从回调内部调用API函数。

CURLE_OBSOLETE *

永远不会返回这些错误代码。它们在旧的libcurl版本中使用,目前尚未使用。

CURLMcode
这是libcurl多接口中函数使用的通用返回码。还要考虑curl_multi_strerror。

CURLM_CALL_MULTI_PERFORM(-1)

这不是一个真正的错误。这意味着您应该再次调用curl_multi_perform,而不要在其间执行select()或类似操作。在版本7.20.0之前,这可以通过curl_multi_perform返回,但在以后的版本中,此返回代码从不使用。

CURLM_OK(0)

事情很好。

CURLM_BAD_HANDLE(1)

传入的句柄不是有效的CURLM句柄。

CURLM_BAD_EASY_HANDLE(2)

容易处理不好/有效。这可能意味着它根本不是一个简单的手柄,或者可能是手柄已被这个或另一个多手柄使用。

CURLM_OUT_OF_MEMORY(3)

你注定要失败。

CURLM_INTERNAL_ERROR(4)

这只能在libcurl错误时返回。请向我们报告!

CURLM_BAD_SOCKET(5)

传入的套接字不是libcurl已经知道的有效套接字。(在7.15.4中添加)

CURLM_UNKNOWN_OPTION(6)

curl_multi_setopt()带有不支持的选项(在7.15.4中添加)

CURLM_ADDED_ALREADY(7)

已尝试添加到多手柄的简易手柄第二次添加。(在7.32.1中添加)

CURLM_RECURSIVE_API_CALL(8)

从回调内部调用API函数。

CURLSHcode
“share”接口将返回CURLSHcode以指示何时发生错误。还要考虑curl_share_strerror。

CURLSHE_OK(0)

一切都很好。像往常一样继续。

CURLSHE_BAD_OPTION(1)

传递给函数的选项无效。

CURLSHE_IN_USE(2)

共享对象当前正在使用中。

CURLSHE_INVALID(3)

无效的共享对象已传递给该函数。

CURLSHE_NOMEM(4)

没有足够的内存可用。(在7.12.0中添加)

CURLSHE_NOT_BUILT_IN(5)

无法执行请求的共享,因为您使用的库未启用该特定功能。(在7.23.0中添加)

CURLUcode
CURLUE_BAD_HANDLE(1)

应该是CURLU指针的参数作为NULL传入。

CURLUE_BAD_PARTPOINTER(2)

NULL指针被传递给curl_url_get的‘part‘参数。

CURLUE_MALFORMED_INPUT(3)

格式错误的输入传递给URL API函数。

CURLUE_BAD_PORT_NUMBER(4)

端口号不是0到65535之间的十进制数。

CURLUE_UNSUPPORTED_SCHEME(5)

此libcurl构建不支持给定的URL方案。

CURLUE_URLDECODE(6)

URL解码错误,很可能是因为输入中有垃圾。

CURLUE_OUT_OF_MEMORY(7)

记忆功能失败。

CURLUE_USER_NOT_ALLOWED(8)

禁止时,凭据在URL中传递。

CURLUE_UNKNOWN_PART(9)

未知的部件ID已传递给URL API函数。

CURLUE_NO_SCHEME(10)

URL中没有方案部分。

CURLUE_NO_USER(11)

URL中没有用户部分。

CURLUE_NO_PASSWORD(12)

URL中没有密码部分。

CURLUE_NO_OPTIONS(13)

URL中没有选项部分。

CURLUE_NO_HOST(14)

URL中没有主机部分。

CURLUE_NO_PORT(15)

URL中没有端口部分。

CURLUE_NO_QUERY(16)

URL中没有查询部分。

CURLUE_NO_FRAGMENT(17)

URL中没有片段部分。

 

以上是关于PHP CURL_ERRNO 77的主要内容,如果未能解决你的问题,请参考以下文章

cURL函数库错误码说明之PHP curl_errno函数

超级有用的9个PHP代码片段

PHP必用代码片段

PHP代码-psysh调试代码片段工具

带有php错误的Paypal NVP

超实用的php代码片段