maxTotalHeaderLength是否按预期工作



Warp有一个默认为50*1024的settingsMaxTotalHeaderLength字段:https://hackage.haskell.org/package/warp-3.3.10/docs/src/Network.Wai.Handler.Warp.Settings.html#defaultSettings

我想这意味着50KB?但是,当我尝试发送一个约33KB的标头时,服务器抛出了错误的请求:

curl -v -w '%{size_request} %{size_upload}' -H @temp.log localhost:8080/v1/version

结果:

*   Trying 127.0.0.1...
* TCP_NODELAY set
* Connected to localhost (127.0.0.1) port 8080 (#0)
> GET /v1/version HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/7.58.0
> Accept: */*
> myheader2: <big header snipped>
> 
* HTTP 1.0, assume close after body
< HTTP/1.0 400 Bad Request
< Date: Wed, 22 Jul 2020 13:15:19 GMT
< Server: Warp/3.3.10
< Content-Type: text/plain; charset=utf-8
< 
* Closing connection 0
Bad Request33098 0

(注意,请求大小为33098(

同样的事情也适用于32.5KB的头文件。

我真正的问题实际上是,我需要设置settingsMaxTotalHeaderLength = 160000来发送大小为~55KB的标头。不确定这是一个错误还是我看错了什么?

祝贺您,您似乎在warp中发现了一个错误。在push的定义中,有一些重复计数。在顶部附近,bsLen被计算为到目前为止标头的完整长度,但在添加换行空闲块的push' Nothing情况下,长度被更新为:

len' = len + bsLen

当CCD_ 7已经占CCD_。在其他push'情况下也存在类似的问题,其中startend偏移到完整标头中,因此不应添加到len