gpt4 book ai didi

c++ - "Content-Length"或 "chunked transfer-encoding"是Http请求必须的吗?

转载 作者:太空宇宙 更新时间:2023-11-03 19:54:39 25 4
gpt4 key购买 nike

有人可以告诉我有关 Content-Length 或 Transfer-Encoding 的信息:“Chunked”是 Http 请求的必须条件吗?我正在使用 C++ 编写一个 http 服务器。

http响应可以使用close socket来知道消息体的长度。但是请求呢?

我查过 RFC2616 关于 http 1.1 的内容,但我对此还不够清楚。

我的问题是,如果发送的http请求没有“Content-Length”或“Chunked Transfer-Encoding”,我如何使用“WSARecv”来知道消息正文的长度,对于我使用WSARecv并获取所有内容的情况标题和网络流恰好以“\r\n\r\n”结尾,我无法获取消息正文的长度。如果我再次发送 WSARecv,它可能会永远等待,因为没有更多数据。如果我不再发送“WSARecv”,如果有的话,我可能无法收到消息正文。

或者“内容长度”和“分块传输编码”可能是http请求所必需的?客户端应该设置其中之一来告诉服务器消息的长度?

最佳答案

如果您未指定 Transfer-EncodingContent-Length,则请求(或响应)隐式是可变长度请求/响应,并且是唯一的方法发出主体结束信号就是关闭连接(并相反地检测接收器中的关闭/eof)。

这意味着这种请求/响应也是隐式Connection: close

如果您要实现 HTTP1.1,那么您必须支持所有三种传输方法。

当我编写 HTTP 服务器时,我从“连接流”的概念中抽象出了“请求流”的概念。 “请求流”是多态的,并且支持读取“EOF”的概念。没有理由你不能有一个方法来“read_chunk”。在非分块请求的情况下,可以简单地读取直到 EOF。

这使我能够在同一连接上同时执行多个请求(但有一些棘手的问题来确保响应以正确的顺序返回!)

关于c++ - "Content-Length"或 "chunked transfer-encoding"是Http请求必须的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59604725/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com