博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RCA:未注意Curl-library Post 1024以上字节时的HTTP/1.1特性导致 HessianPHP 传输数据失败...
阅读量:4502 次
发布时间:2019-06-08

本文共 2005 字,大约阅读时间需要 6 分钟。

先列出 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
“,造成请求逻辑出错。
( 注1:lighttpd
  ,于1.5版本修复。
注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
 

其他知识背景:
  • 根据 所述,”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:") 

p.s.:
    有人认为改为 HTTP/1.0 协议即可绕过这个 100-continue 问题,但这只是工程师不愿意搞清楚原理而示弱的表现。
 
参考资源:
1)2011,Laruence, ;
2)PHP手册, ;
3)HTTP 1.1 RFC, ;
4)stackoverflow,2009, ;
5)zxgfa,2012, ;
6)lighttpd,2009, ;

赠图几枚:
请施主拿去:
360度后空翻开球:
360无死角:
 

 

转载于:https://www.cnblogs.com/zhengyun_ustc/p/100continue.html

你可能感兴趣的文章
[开源]jquery-ajax-cache:快速优化页面ajax请求,使用localStorage缓存请求
查看>>
Android Sqite数据库 <7>
查看>>
利用Excel导入数据到SAP C4C
查看>>
.NET WebApi使用Swagger
查看>>
Python装饰器实现类Java注解功能
查看>>
django二次开发对接FastDFS
查看>>
【linux-查阅文件】more & less
查看>>
ASP.NET使用FCKEditor_2.6.6与FCKeditor.Net_2.6.3配置(转载)
查看>>
POJ3264 Balanced Lineup
查看>>
Go Walk教程 - 流程控制( switch)
查看>>
JDK中NIO
查看>>
Foobar2000–panel stack splitter
查看>>
设置button图片和文字
查看>>
web前端升级之路
查看>>
Openframework在VS2010中的配置
查看>>
发生死锁怎么办
查看>>
webpack使用时可能出现的问题
查看>>
zh-cn、en-us、zh-tw等表示语言(文化)代码与国家地区对照表(最全的各国地区对照表)...
查看>>
C++ STL 之 函数对象适配器
查看>>
hdu1276(士兵队列训练问题) java集合水过
查看>>