gpt4 book ai didi

asp.net - IIS 以两个响应响应单个请求

转载 作者:塔克拉玛干 更新时间:2023-11-01 19:10:07 25 4
gpt4 key购买 nike

我们有一个用户向我们的网络服务器(windows server 2003,IIS 6)发送 POST。他们从我们的 webapp 得到了完整的响应,但随后 IIS 也响应了“400 Bad Request”。没有提供其他信息(是的,我关闭了友好错误)。

起初,我认为可能是某些中间件在其中注入(inject)了响应。但是,我能够在 HTTPSys 错误日志中找到以下内容,确认它来 self 们的服务器:

2013-08-09 23:36:40 11901 80 HTTP/0.0 未解析 - 400 - BadRequest -

这些错误堆积如山,我不知道为什么。 Unparsed 并没有真正告诉我任何事情,所以我没有太多要继续的。我能够让他们生成一个 wireshark 跟踪,这表明我们确实以完全正确的响应进行了响应,然后附加了一个 400 错误的请求响应。我从 wireshark 中完全复制了他们的请求,并在我的机器上进行了尝试,当然,我无法重现它(我得到了一个有效的响应)。

所以我完全无法重现“Unparsed”错误,但是我能够从一个请求中得到两个响应。我故意打破了请求 header 和正文之间的行结尾,然后我得到了一个完整的正确响应,后面跟着“错误的请求(无效的动词)”。

两个问题

1) 有没有人知道如何在 HTTPsys 日志中产生“Unparsed”错误?关于如何复制这个有什么想法吗?

2) 为什么 IIS 用两个响应来响应单个请求?这是正常行为,还是表明存在配置错误?

感谢任何愿意为这个可怕的头痛提供帮助的人!

最佳答案

在这里回答我自己的问题,因为我不希望这种痛苦发生在任何其他人身上。

原来他们的 POST 在内容长度上有一个小错误,我认为它不包括最后的“\r\n”,但不管是什么计数最终都少了 2。

当我复制确切的请求并从我的机器发送它时,它从未出现的原因是我没有正确关闭连接。出于某种原因,关闭与 FIN 的连接实际上会有所不同并导致 400 Bad Request。

不确定为什么会发生这种情况,也许在 FIN 到来时以某种方式读取了初始请求中发送的额外字符?我不知道,但你知道了。修复内容长度,痛苦就会消失。

关于asp.net - IIS 以两个响应响应单个请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18238843/

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