什么是防止memcached CacheKeyWarning的好/结构化方法?

时间:2012-10-11 22:40:47

标签: django caching memcached

我想知道是否有人知道一种方便的方法或方法,以确保您传递给django.core.cache.set()cache.get()的密钥没问题。

来自https://docs.djangoproject.com/en/1.3/topics/cache/#cache-key-warnings

  

Memcached是最常用的生产缓存后端,但却没有   允许超过250个字符或包含空格的缓存键   或控制字符,使用这些键会导致异常。

我在这里找到了md5_constructor()函数:https://github.com/django/django/blob/master/django/utils/hashcompat.py

也许一种方法是md5-如果你总是使用的键?不确定是否安全。

2 个答案:

答案 0 :(得分:5)

您可能想要使用自定义键功能https://docs.djangoproject.com/en/dev/ref/settings/#std:setting-CACHES-KEY_FUNCTION

在您的设置中进行设置:

CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'KEY_FUNCTION': 'path.to.my.make_key',
        'LOCATION': [
            '127.0.0.1:11211',
        ]
    }
}

我会使用类似的东西:

from django.utils.encoding import smart_str

def _smart_key(key):
    return smart_str(''.join([c for c in key if ord(c) > 32 and ord(c) != 127]))

def make_key(key, key_prefix, version):
    "Truncate all keys to 250 or less and remove control characters"
    return ':'.join([key_prefix, str(version), _smart_key(key)])[:250]

答案 1 :(得分:4)

  1. md5_constructor在标准库中为hashlib.md5,其digest方法可以返回符合长度限制的安全密钥。如果原始密钥的长度大于250,则应使用它或其他密钥使密钥安全。
  2. 对于原始密钥中的每个字符,请确保ord(character) >= 33,如果没有,请使用下划线或其他您喜欢的安全字符替换不安全字符。