博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTTP之put/post请求头中的Expect:100-continue
阅读量:4167 次
发布时间:2019-05-26

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

在使用curl封装的HTTPClient时,在上传文件的put方法中,通过抓包抓包数据分析,发现在每次真正传输数据之前都必须要收到Server端的响应:HTTP/1.1 100 Continue,这无疑增加了请求的时间;

使用 curl 发送 POST 请求时,如果 POST 数据大于 1024字节,curl 默认行为 如下:

  1. 先追加一个Expect: 100-continue请求头信息,发送这个不包含 POST 数据的请求;
  2. 如果服务器返回的响应头信息中包含Expect: 100-continue,则表示 Server 愿意接受数据,这时才 POST 真正数据给 Server;

因此如果client预期等待“100-continue”的应答,那么它发送的请求必须包含一个“Expect: 100-continue” ;

可见此时,curl 发送了一次不必要的 HTTP 请求,从系统性能上来说这是不允许的。另外,并不是所有的 Server 都会正确响应100-continue,反而会返回417 Expectation Failed,curl 端不会发起数据 POST 请求,则会造成业务逻辑错误,我们应该避免这种情况的发生。

解决办法:

只需 设置 Expect 请求头为空 即可。

在封装接口时,我们可以做如下的则设置:

struct curl_slist *headers = NULL;	headers = curl_slist_append(headers, "Expect:");  //注意此处的操作	headers = curl_slist_append(headers, "Connection:keep-alive");	/* 1: set http server url */	curl_easy_setopt(curl, CURLOPT_URL, serv_url);	// 3.4:put & upload	curl_easy_setopt(curl, CURLOPT_UPLOAD, 1);	curl_easy_setopt(curl, CURLOPT_PUT, 1);	curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);	curl_easy_setopt(curl, CURLOPT_READFUNCTION, upload_read_func);	curl_easy_setopt(curl, CURLOPT_READDATA, fp);	curl_easy_setopt(curl, CURLOPT_INFILESIZE, local_file_length);	curl_easy_setopt(curl, CURLOPT_CONNECTTIMEOUT, 10L);	/* abort if slower than 1 bytes/sec during 6 seconds */	curl_easy_setopt(curl, CURLOPT_LOW_SPEED_LIMIT, 1);	curl_easy_setopt(curl, CURLOPT_LOW_SPEED_TIME, 6);        ......

再次抓包,发现使用 curl 发送超过 1024字节 的 PUT/POST 数据时,也并未出现 100-continue 的 HTTP 请求。

转载地址:http://mjqxi.baihongyu.com/

你可能感兴趣的文章
工作流审批平台-审批流程-指定审批部门
查看>>
商务智能-系统概述-数据图形方式
查看>>
软件项目管理系统-项目管理-模块定义-开发内容
查看>>
工作流审批平台-审批功能
查看>>
商务智能-基本方法-特征与角度
查看>>
软件项目管理系统-项目管理-模块定义-开发笔记
查看>>
工作流审批平台-业务申请-申请书一览
查看>>
商务智能-基本方法-数据钻取
查看>>
eclipse的java facets的runtimes如何删除tomcat?
查看>>
oracle序列的cache_size说明
查看>>
oracle中两个时间戳相减得到间隔毫秒数
查看>>
Oracle中将毫秒数转换为timestamp类型的两种方法
查看>>
mybatis配置and rownum< minus 查询第几行到第几行数据的sql原型和mybatis原型。
查看>>
oracle的concat函数使用问题。
查看>>
eclipse编辑状态下怎样让指定行左移或右移?
查看>>
plsql developer如何导入导出表结构和数据以及如何复制表结构和数据?
查看>>
oracle如何去除某个字段中两边的空格?
查看>>
plsql developer如何在窗口列表直接可以修改表格中的数据?
查看>>
java自定义注解有什么作用?
查看>>
ORACLE中通过SQL语句(alter table)来增加、删除、修改字段
查看>>