Получение ключевой ошибки в базе данных БД django-digest - PullRequest
1 голос
/ 12 июня 2010

Я только что начал интегрировать django_digest в свое приложение.Для начала я добавил декоратор @httpdigest к одному из моих просмотров.Если я пытаюсь подключиться к нему, я получаю исключение KeyError, брошенное в django_digest / backend / db.py.В зависимости от того, какую БД я настраиваю, я получаю другую KeyError в другом месте.Я использую Django 1.2.1 с MySql (также протестирован с sqlite).Я использую значения по умолчанию для всех параметров настройки.

Насколько я вижу, я следовал всем инструкциям, но борюсь с этим весь день.Я использую версии репозитория django-digest и python-digest.Любая бычка будет принята с благодарностью.

Ниже приведены трассировки для sqlite и mysql:

с sqlite:

Traceback (most recent call last):
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/servers/basehttp.py", line 674, in __call__
    return self.application(environ, start_response)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/handlers/wsgi.py", line 248, in __call__
    signals.request_finished.send(sender=self.__class__)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/dispatch/dispatcher.py", line 162, in send
    response = receiver(signal=self, sender=sender, **named)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django_digest-1.8-py2.5.egg/django_digest/backend/db.py", line 16, in close_connection
    _connection.close()
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/db/backends/sqlite3/base.py", line 186, in close
    if self.settings_dict['NAME'] != ":memory:":
KeyError: 'NAME'

с mysql:

Traceback (most recent call last):
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/servers/basehttp.py", line 674, in __call__
    return self.application(environ, start_response)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/handlers/wsgi.py", line 241, in __call__
    response = self.get_response(request)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/handlers/base.py", line 142, in get_response
    return self.handle_uncaught_exception(request, resolver, exc_info)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/handlers/base.py", line 166, in handle_uncaught_exception
    return debug.technical_500_response(request, *exc_info)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/core/handlers/base.py", line 80, in get_response
    response = middleware_method(request)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django_digest-1.8-py2.5.egg/django_digest/middleware.py", line 13, in process_request
    if (not self._authenticator.authenticate(request) and
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django_digest-1.8-py2.5.egg/django_digest/__init__.py", line 86, in authenticate
    partial_digest = self._account_storage.get_partial_digest(digest_response.username)
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django_digest-1.8-py2.5.egg/django_digest/backend/db.py", line 97, in get_partial_digest
    cursor = get_connection().cursor()
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/db/backends/__init__.py", line 75, in cursor
    cursor = self._cursor()
  File "/home/robm/projects/gcs/server/gcs2.5/lib/python2.5/site-packages/django/db/backends/mysql/base.py", line 281, in _cursor
    if settings_dict['USER']:
KeyError: 'USER'

Обновление - похоже, что это специфично для Django 1.2 и бэкэнда нескольких баз данных.Изменение оболочки базы данных в backend / db.py django_digest из:

_connection = backend.DatabaseWrapper({                                          
        'DATABASE_HOST': settings.DATABASE_HOST,                                 
        'DATABASE_NAME': settings.DATABASE_NAME,                                 
        'DATABASE_OPTIONS': settings.DATABASE_OPTIONS,                           
        'DATABASE_PASSWORD': settings.DATABASE_PASSWORD,                         
        'DATABASE_PORT': settings.DATABASE_PORT,                                 
        'DATABASE_USER': settings.DATABASE_USER,                                 
        'TIME_ZONE': settings.TIME_ZONE,                                         
        })                                                                       

примерно таким образом:

_connection = backend.DatabaseWrapper({
                'HOST': settings.DATABASE_HOST,
                'NAME': settings.DATABASE_NAME,
                'OPTIONS': settings.DATABASE_OPTIONS,
                'PASSWORD': settings.DATABASE_PASSWORD,
                'PORT': settings.DATABASE_PORT,
                'USER': settings.DATABASE_USER,
                'TIME_ZONE': settings.TIME_ZONE,
                })

должно исправить это.

На данный момент я переключилсявместо использования HTTPBasicAuth с https, но, надеюсь, на следующей неделе у меня появится возможность сделать патч.

1 Ответ

0 голосов
/ 13 июня 2011

Чтобы этот вопрос показывался как ответ, я добавляю решение, которое я добавил в комментарии выше, в качестве ответа (это правильно?):

похоже, что это специфично для Django 1.2 и многобазового бэкэнда. Изменение оболочки базы данных в бэкэнде django_digest / db.py из:

_connection = backend.DatabaseWrapper({                                          
    'DATABASE_HOST': settings.DATABASE_HOST,                                 
    'DATABASE_NAME': settings.DATABASE_NAME,                                 
    'DATABASE_OPTIONS': settings.DATABASE_OPTIONS,                           
    'DATABASE_PASSWORD': settings.DATABASE_PASSWORD,                         
    'DATABASE_PORT': settings.DATABASE_PORT,                                 
    'DATABASE_USER': settings.DATABASE_USER,                                 
    'TIME_ZONE': settings.TIME_ZONE,                                         
    })         

что-то вроде:

_connection = backend.DatabaseWrapper({
            'HOST': settings.DATABASE_HOST,
            'NAME': settings.DATABASE_NAME,
            'OPTIONS': settings.DATABASE_OPTIONS,
            'PASSWORD': settings.DATABASE_PASSWORD,
            'PORT': settings.DATABASE_PORT,
            'USER': settings.DATABASE_USER,
            'TIME_ZONE': settings.TIME_ZONE,
            })

Должно это исправить.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...