- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我们有一个用户向我们的网络服务器(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/
当我查看 IIS 日志文件时,我可以在一天中的不同时间看到标题行被写入日志文件。我唯一一次看到这种情况发生是在 IIS 重置时;或启动。 例如下面的标题行; #Software: Microsoft
有谁知道为什么以下 web.conig 更改不起作用: 在我添加 javascript 文件后仍然没有被压缩(gzip)。我折腾了几天,因为一开始我真的不知道问题是
目前,我们所有的网络应用程序都将其应用程序池标识设置为 ApplicationPoolIdentity。现在,当一个应用程序需要访问某些服务器上的某些资源时,比如添加/读取某些文件,该应用程序会在代码
在 IIS(特别是 6.0)中,在“主目录”选项卡下,如果我更改本地路径,是否会导致 IIS 重新启动或应用程序池回收? 相关的,是否有概述 IIS 元数据库的哪些更改将触发重新启动或应用程序池回收的
只要更改了任何 web.config 文件,AFAIK IIS 就会重新启动。 我创建了自己的配置文件(my.config,层次结构略有不同)。是否有可能让 IIS 自动(自动神奇地 :))重新启动,
你好, 我正在寻找 IIS 日志中列出的浏览器条目列表,以帮助识别访问我们网站的不同版本的浏览器。也许没有一个列表,而是一个应该用来识别不同浏览器及其版本的算法。 请注意,我不是在寻找日志分析器,而是
我想知道上次重新启动 iis 是什么时候。 IIS 是否保留了此日志,我在哪里可以找到此日志? 谢谢 最佳答案 打开事件查看器,导航到“Windows 日志”->“系统” 在右侧的“操作” Pane
在全新安装的带有 IIS 7 的 Windows Server 2008 R2 上,它会在 C:\inetpub\wwwroot 中创建一个默认网站。 .我确信对于存储网站文件的好位置有很多主观意见,
我已按照 this question 中的说明在 IIS 中实现动态内容压缩。 . 当我发送请求时,我看不到响应被 gzip 压缩的任何证据: IIS版本为7.5 有什么明显的我应该检查以解决此问题吗
这是场景: 服务器 A 托管“主”应用程序 (www.example.com) 服务器 B 托管支持应用程序 (b.example.com) 它们通过 192.* 地址在内部相互连接,并且都可以通过
是否有任何替代 IIS 管理 UI 可用于从程序重置 IIS?.. 现在我们已经创建了一个批处理文件,如果 iis 重置并每小时安排一次...... 我只是想要一些东西,这样我们就不能重置 iis..
我的 Windows Server 在 IIS 7.5 上运行 Web 应用程序。 我想知道为什么 IIS 应用程序池使用大量内存。 请参阅我从服务器捕获的屏幕截图。 在名为 TEST 2.0(.NE
我在 IIS 7.5 上运行的 ASP Classic 站点上收到服务器错误。 我将“向浏览器发送错误”设置为 True ,但是我仍然收到以下错误屏幕: 最佳答案 IIS 正在劫持您的经典 ASP 应
我正在尝试通过IIS上的反向代理连接到websockets服务器(websockify)。 IIS和Websockets服务器位于同一台物理服务器上(Windows Server 2012 R2,II
我需要让我的开发机器从本地机器商店读取证书 为此,我需要运行winhttpcertcfg.exe并指定我要提升的帐户 该帐户用于IIS表示什么? (对于IIS,它将是IWAM_MachineName)
我正在阅读特定命令(SET-WEBCONFIGURATIONPROPERTY),但出现"is not recognized as a cmdlet"错误。给我的建议是,即使我使用的是SharePoin
我已经为 IIS8 安装了静态和动态压缩并启用了它。 当我的CPU性能100%时,我的GZIP IIS不工作,为什么? 我可以清楚地看到 GZIP 没有在 Live HTTP header 中运行。我
我已经从官方镜像(https://hub.docker.com/r/microsoft/iis/)运行了IIS 在Windows Server 2016上 有什么方法可以从IIS管理器连接到该IIS,
你好, 如果 iis 未运行,我想编写一个状态为的代码。 最佳答案 从命令行启动 IIS: iisreset /start 从命令行停止 IIS: iisreset /stop 重新启动(停止和启动)
我已经为 IIS8 安装了静态和动态压缩并启用了它。 当我的CPU性能100%时,我的GZIP IIS不工作,为什么? 我可以清楚地看到 GZIP 没有在 Live HTTP header 中运行。我
我是一名优秀的程序员,十分优秀!