Opened 17 years ago
Closed 14 years ago
#6507 closed (fixed)
[proposal] Create extension to Python Cookie module
Reported by: | David Cramer | Owned by: | nobody |
---|---|---|---|
Component: | HTTP handling | Version: | dev |
Severity: | Keywords: | ||
Cc: | qingfeng@… | Triage Stage: | Someday/Maybe |
Has patch: | yes | Needs documentation: | no |
Needs tests: | yes | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
Create an extension to the Python Cookie module to help solve issues with cookie key/value errors.
By subclassing the SimpleCookie module you can add support into it to try/except on the set method so invalid cookies get thrown away, but valid cookies are not lost.
File "/home/curseweb/cursedjango/django/django/utils/defensive.py", line 65, in inner_email_exceptions return func(*args, **kwargs) File "/home/curseweb/cursedjango/cursesite/middleware/cookies.py", line 13, in process_request for k, v in request.COOKIES.iteritems(): File "/home/curseweb/cursedjango/django/django/core/handlers/modpython.py", line 83, in _get_cookies self._cookies = http.parse_cookie(self._req.headers_in.get('cookie', '')) File "/home/curseweb/cursedjango/django/django/http/__init__.py", line 160, in parse_cookie c.load(cookie) File "/usr/local/lib/python2.4/Cookie.py", line 621, in load self.__ParseString(rawdata) File "/usr/local/lib/python2.4/Cookie.py", line 652, in __ParseString self.__set(K, rval, cval) File "/usr/local/lib/python2.4/Cookie.py", line 574, in __set M.set(key, real_value, coded_value) File "/usr/local/lib/python2.4/Cookie.py", line 453, in set raise CookieError("Illegal key value: %s" % key) CookieError: Illegal key value: ??est
Attachments (3)
Change History (12)
comment:1 by , 17 years ago
comment:3 by , 17 years ago
Triage Stage: | Unreviewed → Someday/Maybe |
---|
This is probably a someday/maybe feature. However, in the sample code given, trying to decode the cookie value as UTF-8 (or with any encoding) isn't correct. Cookie data should be treated as opaque, because there's no uniformly respected standard for encoding there. It's up to the client app to make sure that ASCII data is sent out and then decode it as appropriate.
by , 16 years ago
Attachment: | __init__.patch added |
---|
by , 16 years ago
Attachment: | django_http_init_11315.patch added |
---|
comment:5 by , 16 years ago
Needs tests: | set |
---|
Unit Test:
from django.test import TestCase from django import http class SimpleTest(TestCase): def test_basic_addition(self): cookie_str = 'name=qingfeng;???=456;'#Error Cookie! cookie = http.parse_cookie(cookie_str) self.assertTrue('name' in cookie) self.assertEqual(cookie['name'],'qingfeng')
Error Log:
F ====================================================================== FAIL: test_basic_addition (fixbug.tests.SimpleTest) ---------------------------------------------------------------------- Traceback (most recent call last): File "/private/tmp/cookierror/fixbug/tests.py", line 16, in test_basic_addition self.assertTrue('name' in cookie) AssertionError ---------------------------------------------------------------------- Ran 1 test in 0.003s
comment:6 by , 16 years ago
milestone: | → 1.2 |
---|
comment:7 by , 16 years ago
This bug will affect mod_python and wsgi reading session, because "cookie.load (str)" error, all the cookie will be cleared
comment:8 by , 15 years ago
milestone: | 1.2 |
---|
comment:9 by , 14 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
Here is some code (credits to the guys at pocoo.org for the solution). This is just an example solution, thus no diff (as I'd have to install trunk to do the diff :P). If it's accepted I can create a patch.