先列出 HessianPHP 的错误提示:
CURL transport error: transfer closed with outstanding read data remaining
基础知识背景:
1)“Expect: 100-continue”的来龙去脉:
HTTP/1.1 协议里设计 100 (Continue) HTTP 状态码的的目的是,在客户端发送 Request Message 之前,HTTP/1.1 协议允许客户端先判定服务器是否愿意接受客户端发来的消息主体(基于 Request Headers)。
即,Client 和 Server 在 Post (较大)数据之前,允许双方“握手”,如果匹配上了,Client 才开始发送(较大)数据。
这么做的原因是,如果客户端直接发送请求数据,但是服务器又将该请求拒绝的话,这种行为将带来很大的资源开销。
协议对 HTTP/1.1 clients 的要求是:
如果 client 预期等待“100-continue”的应答,那么它发的请求必须包含一个 "Expect: 100-continue" 的头域!
2)libcurl 发送大于1024字节数据时启用“Expect:100-continue‘特性:
这也就是 Laruence 在 2011 年撰文所写的:
在使用 curl 做 POST 的时候,当要 POST 的数据大于 1024 字节的时候,curl 并不会直接就发起 POST 请求,而是会分为两步:1. 发送一个请求,包含一个 "Expect: 100-continue" 头域,询问 Server 是否愿意接收数据;2. 接收到 Server 返回的 100-continue 应答以后,才把数据 POST 给 Server;这是 libcurl 的行为。
zxgfa 在 2012年补充说:
第一,libcurl 在发送大于 1024 字节的 POST 请求时采用了这种方法,但是相对的,它会引起请求延迟的加大。第二,并不是所有的 web server 都能正确处理并应答“100-continue”,比如 lighttpd,就会返回417”Expectation Failed“,造成请求逻辑出错。郑昀注2:Resin 于 3.0.5 版本增加了对 Expect: 100-continue 的支持。)
3)PHP Curl-library 可以主动封禁此特性:
PHP curl 遵从 libcurl 的特性。由于不是所有 web servers 都支持这个特性,所以会产生各种各样的错误。如果你遇到了,可以用下面的命令封禁"Expect"头域:
<?php
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:'));
?>
pooy示范代码如下所示:
图1 You can convince PHP's curl backend to stop doing the 100-continue-thing by setting an explicit request header
其他知识背景:
- 根据 HessianTransport 代码所述,”Hessian request using the CURL library“。
问题现象:
通信协议是 Hessian。调用接口时所传参数在某种极端条件下,POST 的数据长度超过 1024 字节,hessian 报错“CURL transport error: transfer closed with outstanding read data remaining”。
解决:
修改hessian中 CURLOPT 项:
CURLOPT_HTTPHEADER => array("Content-Type: application/binary")
改为
CURLOPT_HTTPHEADER => array("Content-Type: application/binary","Expect:")
参考资源:
1)2011,Laruence,Expect:100-continue;
3)HTTP 1.1 RFC,Use of the 100 (Continue) Status;
4)stackoverflow,2009,PHP HTTP POST fails when cURL data > 1024;
5)zxgfa,2012,libcurl的使用问题“Expect100-continue”;
6)lighttpd,2009,'Expect' header gives HTTP error 417;
赠图几枚:
请施主拿去:
360度后空翻开球:
360无死角:
相关推荐
HTTP linux POST
后台 用curl模拟post 提交数据 调取接口
curl --location --request GET 'http://127.0.0.1:8000/loans/get-excel-for-loans' 回复 { "download_link": "http://127.0.0.1:8000/media/loans.csv" } 2.浏览书籍 curl --location --request GET '...
curl -s -L -o /usr/bin/cfssl https://pkg.cfssl.org/R1.2/cfssl_linux-amd64 && \ curl -s -L -o /usr/bin/cfssljson https://pkg.cfssl.org/R1.2/ cfssljson_linux-amd64 && \ curl -s -L -o /usr/bin/cfssl-...
curl-7.59.0.zip,执行post请求,方便下载curl-7.59.0.zip,执行post请求,方便下载
这已经下载好了,下载之后,通过 bash ./downloadbyfn.sh 1.1.0 -s 运行。 具体可以看https://blog.csdn.net/u013288190/article/details/112286162
curl-8.4.0_3-win32-mingw.zip curl-8.4.0_3-win64-mingw.zip curl-8.4.0_3-win64a-mingw.zip
yum报错处理,引入文件到缺失目录下即可
如果是 Windows 系统,下载 window 版本(curl-7.33.0-win64-ssl-sspi.zip解压后的curl.exe文件,添加到环境变量中,以便在其他路径中通过cmd窗口使用curl命令): 如果你安装了 git shell,也自带了 curl。
curl 命令详解 curl 命令详解 一、参数详解   -M/--manual 显示全手动 -n/--netrc ...--netrc-optional 使用.netrc 或者URL 来覆盖-n ...文件传输前,发送命令到服务器 ...检索来自HTTP/1.1 或FTP 服务器字节范
curl-8.4.0.tar.gz curl-8.4.0.zip
用法docker pull dwdraju/alpine-curl-jq镜像docker pull dwdraju/alpine-curl-jq例子卷曲docker run --rm mtandersson/alpine-curl-jq curl https://www.google.com卷曲,jq docker run --rm mtandersson/alpine-...
56:在接收网络数据时失败。 58:本地证书有问题。 59:无法使用指定的SSL密码。 60:peer证书无法被已知的CA证书验证。 61:无法辨识的传输编码。 62:无效的LDAP URL。 63:超过最大文件尺寸。 64:要求的FTP的SSL水平失败...
安装要安装PHP Curl类,只需: $ composer require php-curl-class/php-curl-class对于最新的提交版本: $ composer require php-curl-class/php-curl-class @dev要求PHP Curl类可与PHP 5.3、5.4、5.5、5.6、7.0、...
curl-curl-7_47_1.zip
latest curl-7.61.1_6-win32-mingw, downloaded from https://curl.haxx.se/download.html
curl-7.46.0-win64curl-7.46.0-win64curl
curl-curl-7_53_1
今天在linux中使用curl发送一个post请求时,带有json的数据,在发送时发现json中的变量没有解析出来 如下 curl -i -X POST -H 'Content-type':'application/json' -d {BTime:$btime} http://api.baidu.com 变量...
cURL是一个利用URL语法在命令行下工作的文件传输工具,1997年首次发行。它支持文件上传和下载,所以是综合传输工具,但按传统,习惯称cURL为下载工具。cURL还包含了用于程序开发的libcurl。 cURL支持的通信协议有FTP...