mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #19356 -- Increased session key entropy.
This commit is contained in:
@@ -6,6 +6,7 @@ try:
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
import string
|
||||
|
||||
from django.conf import settings
|
||||
from django.core.exceptions import SuspiciousOperation
|
||||
@@ -15,6 +16,10 @@ from django.utils.crypto import salted_hmac
|
||||
from django.utils import timezone
|
||||
from django.utils.encoding import force_bytes
|
||||
|
||||
# session_key should not be case sensitive because some backends can store it
|
||||
# on case insensitive file systems.
|
||||
VALID_KEY_CHARS = string.ascii_lowercase + string.digits
|
||||
|
||||
class CreateError(Exception):
|
||||
"""
|
||||
Used internally as a consistent exception type to catch from save (see the
|
||||
@@ -132,12 +137,8 @@ class SessionBase(object):
|
||||
|
||||
def _get_new_session_key(self):
|
||||
"Returns session key that isn't being used."
|
||||
# Todo: move to 0-9a-z charset in 1.5
|
||||
hex_chars = '1234567890abcdef'
|
||||
# session_key should not be case sensitive because some backends
|
||||
# can store it on case insensitive file systems.
|
||||
while True:
|
||||
session_key = get_random_string(32, hex_chars)
|
||||
session_key = get_random_string(32, VALID_KEY_CHARS)
|
||||
if not self.exists(session_key):
|
||||
break
|
||||
return session_key
|
||||
|
@@ -4,7 +4,7 @@ import os
|
||||
import tempfile
|
||||
|
||||
from django.conf import settings
|
||||
from django.contrib.sessions.backends.base import SessionBase, CreateError
|
||||
from django.contrib.sessions.backends.base import SessionBase, CreateError, VALID_KEY_CHARS
|
||||
from django.core.exceptions import SuspiciousOperation, ImproperlyConfigured
|
||||
from django.utils import timezone
|
||||
|
||||
@@ -36,8 +36,6 @@ class SessionStore(SessionBase):
|
||||
cls._storage_path = storage_path
|
||||
return storage_path
|
||||
|
||||
VALID_KEY_CHARS = set("abcdef0123456789")
|
||||
|
||||
def _key_to_file(self, session_key=None):
|
||||
"""
|
||||
Get the file associated with this session key.
|
||||
@@ -48,7 +46,7 @@ class SessionStore(SessionBase):
|
||||
# Make sure we're not vulnerable to directory traversal. Session keys
|
||||
# should always be md5s, so they should never contain directory
|
||||
# components.
|
||||
if not set(session_key).issubset(self.VALID_KEY_CHARS):
|
||||
if not set(session_key).issubset(set(VALID_KEY_CHARS)):
|
||||
raise SuspiciousOperation(
|
||||
"Invalid characters in session key")
|
||||
|
||||
|
Reference in New Issue
Block a user