gpt4 book ai didi

http - 如何在 Erlang 中读取 http POST 请求的主体

转载 作者:可可西里 更新时间:2023-11-01 17:16:42 27 4
gpt4 key购买 nike

我正在使用 Erlang 开发一个服务器实现,它有一个处理 HTTP 请求的接收循环。打开监听套接字并生成接受器后,服务器就可以接收连接了。 TLS 握手完成,客户端连接到服务器并开始发送 HTTPS 请求。

服务器的接收部分使用 ssl:recv/2 用于读取传入请求并设置套接字,以便数据包采用 HttpPacket 的形式.到目前为止,“GET”请求的处理工作正常,但我需要包括“POST”请求。读取“POST”请求也有效,但我似乎无法读取请求的正文。

  1. 我应该如何阅读传入请求的正文?
  2. 是否可以用 ssl:recv/2 读取它?
  3. 套接字是否应该以不同的形式期待或格式化数据?
  4. 你会推荐其他东西吗?

我试过使用 ssl:recv/2 和常规receive .使用 receive卡住服务器直到超时。

case ssl:recv(Tls_socket, 0) of
{ok, {http_request, 'POST', Data, Vsn}} ->
do_something ...

数据最终为 {abs_path, <<"/example/ex">>} .我希望数据成为请求的主体。


我无法读取数据,因为套接字设置为将数据打包为HttpPacket (即 any() )。没有包装的阅读有帮助,所以剩下要做的就是解析查询。

最佳答案

Erlang 内置的 HTTP 解析器一次解析一行。因此,首先您将调用 ssl:recv,并接收 {http_request, 'POST', Path, Vsn},如上例所示。这对应于 HTTP 请求中的 POST/example/ex HTTP/1.1 行。然后你会一遍又一遍地调用 ssl:recv,接收 {http_header, _, Field, _, Value},请求中的每个 header 一个,直到它返回http_eoh,意思是“ header 结束”。

此时,您应该已经收到一个Content-Length header ,因此您知道要从套接字读取多少字节。将套接字切换到“原始”模式(与 HTTP 模式相反):

ssl:setopts(Tls_socket, [{packet, raw}]),

并接收您需要的字节数:

{ok, RequestBody} = ssl:recv(Tls_socket, ContentLength),

并发送响应。

如果您想在同一个套接字上接收另一个 HTTP 请求,请将其切换回 HTTP 模式:

ssl:setopts(Tls_socket, [{packet, http}]),

您提到 receive 超时。这取决于套接字是处于“主动”还是“被动”模式。在“被动”模式下,您需要调用ssl:recv 来接收数据,而在“主动”模式下,传入的数据将作为消息发送到拥有套接字的进程。

您可以通过传递选项 {active, true} 来打开事件模式,但这会冒着您的进程接收传入数据的速度快于其处理速度的风险。通常你会设置选项{active, once},这意味着套接字发送一个消息到进程然后恢复到被动模式,要求你设置选项{active, once} 再次接收更多数据。

关于http - 如何在 Erlang 中读取 http POST 请求的主体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57143056/

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