Eu tenho um servidor IIS 7.5 configurado com o PHP 5.4.5 em execução no FastCgi. O PHP está configurado para retornar dados codificados em gzip se o cliente suportar.
Meu problema é quando eu emito um cabeçalho 303 See Other do PHP, o IIS está colando algum HTML antes dos dados codificados em gzip. Para a maioria dos navegadores, isso não é um problema, eles apenas seguem os cabeçalhos, no entanto meus clientes estão relatando que os redirecionamentos não funcionam através do proxy do Cisco Scansafe, e acho que esse pode ser o motivo.
Aqui estão os dados de pacote capturados com o Wireshark:
GET / HTTP/1.1
Host: [OMITTED]
Connection: keep-alive
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/37.0.2062.124 Safari/537.36
Accept-Encoding: gzip,deflate
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6
Cookie: PHPSESSID=[OMITTED]
HTTP/1.1 303 See Other
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-Type: text/html; charset=UTF-8
Content-Encoding: gzip
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Location: http://[OMITTED]/reports/
Vary: Accept-Encoding
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Fri, 10 Oct 2014 08:15:16 GMT
Content-Length: 246
<head><title>Document Moved</title></head>
<body><h1>Object Moved</h1>This document may be found <a HREF="http://[OMITTED]/reports/">here</a></body>......4....I..(.M.U.OF-.O..K./J-./S.+.(0U.s.....+S..O............5,...
Os bytes codificados em gzip são decodificados por eles mesmos e têm o conteúdo gerado pelo PHP, mas com o IIS HTML é a forma como o pacote HTTP geral não decodifica corretamente, o que pode estar provocando sua rejeição pela Scansafe.
Como posso dizer ao IIS para parar de fazer isso?