ID:               40325
 Updated by:       [EMAIL PROTECTED]
 Reported By:      nicolas dot grekas+php at gmail dot com
-Status:           Open
+Status:           Assigned
 Bug Type:         HTTP related
 Operating System: All
 PHP Version:      5.2.0
 Assigned To:      mike


Previous Comments:
------------------------------------------------------------------------

[2007-03-21 14:42:15] nicolas dot grekas+php at gmail dot com

I'm sorry to insist, but this is for the good of PHP :) This bug is not
bogus.

Here is the related RFC2616 HTTP1.1-14.44 excerpt that is not honored
by ob_gzhandler : "An HTTP/1.1 server SHOULD include a Vary header field
with any cacheable response that is subject to server-driven
negotiation.".

In fact today, ob_gzhandler do send a "Vary: Accept-Encoding" header
when the client accepts gzip or deflate. (This is the case for example
for IE, Gecko, and many browsers.)
BUT : the RFC says that the vary header should be send IF
_a_negociation_occurs_. That means that the Vary header is not meant to
be send based on the result of any negociation. The point is : if you
negociate, then you should send a Vary header, whatever the result of
the nego.

What ob_gzhandler actually does is :
negociate, then if gzip/deflate accepted, send a Vary

What it should do is :
send a Vary, then negociate.


This but is in no way related to the bug of IE regarding vary headers :
the current conditions requested by ob_gzhandler to send its vary header
are always met by IE (accept gzip ? => yes).

Hope it helps

------------------------------------------------------------------------

[2007-02-02 18:44:25] nicolas dot grekas+php at gmail dot com

I knew this pb for IE, and the link of php_lists is worth reading. BUT
it is NOT related to the bug I was submitting.

IE's bug with Vary header is :
IF (non-compressed-content + Vary-header)
THEN IE-dont-cache-entity

Here is my bug :
IF a resource is negotiated for compression
THEN we MUST send a Vary header.

In fact, for IE, the negotiation made by ob_gzhandler DOES ALREADY send
a Vary header. Because negotiation ends to : browser (IE) accepts
gzipped content.

So fixing this issue WONT CHANGE ANYTHING FOR IE, but will fix
corrupted caches.

Should I explain more deeply the issue ?

Regards,
Nicolas

------------------------------------------------------------------------

[2007-02-02 17:02:44] [EMAIL PROTECTED]

Thanks, awesome read.

------------------------------------------------------------------------

[2007-02-02 15:38:48] php_lists at realplain dot com

Just thought I'd add this comment that IE doesn't handle these Vary:
headers correctly (breaks caching that would usually be used). :-( See
http://lists.over.net/pipermail/mod_gzip/2002-December/006826.html

It's been awhile since I read the details, but maybe you'd want to use
"Cache-Control: private" instead or in addition to Vary:?

------------------------------------------------------------------------

[2007-02-02 13:11:50] nicolas dot grekas+php at gmail dot com

Oops : I've switched Expected and Actual results, sorry

------------------------------------------------------------------------

The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
    http://bugs.php.net/40325

-- 
Edit this bug report at http://bugs.php.net/?id=40325&edit=1

Reply via email to