django - nginx+fastcgi -> необработанное исключение (после обновления с Django 1.2.4 до Django 1.3)

Я только что обновился с django 1.2.4 до 1.3.

Я использую nginx в сочетании с fastcgi и по какой-то причине каждый раз, когда я захожу на страницу, я получаю эту ошибку:

Unhandled Exception

An unhandled exception was thrown by the application.

Есть идеи, в чем может быть проблема?

2 ответа

Решение

Чтобы исправить это, я добавил этот класс (который практически ничего не делает) в: /usr/local/lib/python2.6/dist-packages/django/middleware/http.py

class SetRemoteAddrFromForwardedFor(object):
    """
    This middleware has been removed; see the Django 1.1 release notes for
    details.

    It previously set REMOTE_ADDR based on HTTP_X_FORWARDED_FOR. However, after
    investiagtion, it turns out this is impossible to do in a general manner:
    different proxies treat the X-Forwarded-For header differently. Thus, a
    built-in middleware can lead to application-level security problems, and so
    this was removed in Django 1.1

    """
    def __init__(self):
        import warnings
        warnings.warn("SetRemoteAddrFromForwardedFor has been removed. "
                      "See the Django 1.1 release notes for details.",
                      category=DeprecationWarning)
        raise MiddlewareNotUsed()

Вы должны отследить свой журнал ошибок fastcgi. Там должна быть более подробная информация.

Другие вопросы по тегам