аутентификация django для статических файлов

У меня есть набор статических файлов (которые загружаются через приложение), таких как изображения, видео и т. д., которые необходимо предоставить пользователям, прошедшим проверку подлинности (т. е. их файл cookie зарегистрирован как аутентифицированный в сеансе).

Эти файлы являются отдельными и никоим образом не связаны с другими статическими файлами мультимедиа, такими как css, javaacript и т. д.

Учитывая, что мои статические файлы, которые необходимо аутентифицировать, будут довольно большими, мне было интересно, какой будет наиболее эффективный способ их обслуживания (кстати, я использую wsgi).

В настоящее время у меня есть это:

def return_large_file(request, p_filename):
    """                                                                         
    Send a file through Django without loading the whole file into              
    memory at once. The FileWrapper will turn the file object into an           
    iterator for chunks of 8KB.                                                 
    """
    if not os.path.exists(p_filename):
        raise Exception('File %s does not exist!')

    try:
        _content_type = mimetypes.guess_type(p_filename)
    except:
        _content_type = 'application/octet-stream'

    wrapper = FileWrapper(file(p_filename))
    response = HttpResponse(wrapper, content_type=_content_type)
    response['Content-Length'] = os.path.getsize(p_filename)
    return response

person Rok    schedule 13.07.2011    source источник


Ответы (1)


В настоящее время я использую функцию, аналогичную той, что вы используете выше.

Я думал, что когда производительность/эффективность станет проблемой, я буду использовать Apache mod-auth-external для выполнения моей пользовательской авторизации для данного файла.

Обратите внимание, я предлагаю этот ответ не на основе своего опыта, а на основании собственных исследований.

person Firass    schedule 13.07.2011