Пользователей не выбирают, а костыли в виде явного указания немеряного max_length , меня не устраивают.
Я решил сделать так:
1. принимаем картинку
2. запоминаем расширение файла
3. получаем хеш (например md5) от имени + текущее время (чтобы не получать одинаковых хешей для разных картинок с одинаковыми именами)
4. получаем новое имя конкатенацией хеша и расширения
5. сохраняем
Наилучшим местом в коде, куда вклинить этот алгоритм является lfs/core/fields/thumbs.py
Подключаем вспомогательные библиотеки:
+++ b/pydocs/lfs/core/fields/thumbs.py Sun Dec 16 19:17:04 2012 +0400
@@ -7,6 +7,13 @@
except ImportError:
from PIL import Image
+try:
+ from hashlib import md5
+except ImportError:
+ from md5 import md5
+from time import time
def save(self, name, content, save=True):
+ parts = name.split('.')
+ ext = '.%s' % parts[-1] if len(parts) > 1 else ''
+ name = md5("%s-%s"%(name.encode('utf-8'), time())).hexdigest()
+ name = "%s%s"%(name,ext)
super(ImageWithThumbsFieldFile, self).save(name, content, save)
Комментариев нет:
Отправить комментарий
Если Вы нашли ошибку у автора, у Вас есть вопрос или просто хотите поделиться чем-то полезным, то пишите - не стесняйтесь..