Opened 18 years ago

Closed 17 years ago

Last modified 8 years ago

#4994 closed Bug (fixed)

Cookies are not sent back for HTTP Not Modified (304) from CommonMiddleware

Reported by: colin@… Owned by: Malcolm Tredinnick
Component: HTTP handling Version: dev
Severity: Normal Keywords: etags
Cc: Triage Stage: Ready for checkin
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description (last modified by Tim Graham)

The CommonMiddleware functionality generates a new HTTP Response object (304) when the E-Tag matches. This new response does not include the Set-Cookie header, which then breaks the login page from django.contrib.auth.views.login.

This also violates the Cookie specification: If a proxy server receives a response which contains a Set-cookie header, it should propagate the Set-cookie header to the client, regardless of whether the response was 304 (Not Modified) or 200 (OK).

Apache has similar behavior.

The attached patch solves this by moving any set cookies over into the new response object.

Attachments (1)

common-middleware-fix.patch (639 bytes ) - added by colin@… 18 years ago.
Patch for 304 and Cookies

Download all attachments as: .zip

Change History (4)

by colin@…, 18 years ago

Attachment: common-middleware-fix.patch added

Patch for 304 and Cookies

comment:1 by Simon G. <dev@…>, 17 years ago

Triage Stage: UnreviewedReady for checkin

comment:2 by Malcolm Tredinnick, 17 years ago

Resolution: fixed
Status: newclosed

(In [5878]) Fixed #4994 -- Send back set-cookie headers in "not modified" responses. Well spotted, colin@….

comment:3 by Tim Graham, 8 years ago

Description: modified (diff)
Easy pickings: unset
Severity: Normal
Type: Bug
UI/UX: unset
Note: See TracTickets for help on using tickets.
Back to Top