我想知道是否有人知道一种方便的方法或方法,以确保您传递给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,
答案 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)
md5_constructor
在标准库中为hashlib.md5
,其digest
方法可以返回符合长度限制的安全密钥。如果原始密钥的长度大于250,则应使用它或其他密钥使密钥安全。ord(character) >= 33
,如果没有,请使用下划线或其他您喜欢的安全字符替换不安全字符。