所以我刚刚部署了我的第一个django应用程序.
我做了一个syncdb并为该网站创建了我的超级用户帐户.
现在,当我访问该页面并按下登录按钮时,我收到此错误.我认为它与密码有关,但我不确定.
ValueError at /accounts/login/
too many values to unpack
Run Code Online (Sandbox Code Playgroud)
我正在使用通用登录视图
(r'^accounts/login/$', login, {'template_name': 'authentication/login.html'}),
Run Code Online (Sandbox Code Playgroud)
以下是回溯
Environment:
Request Method: POST
Request URL: http://xx.xx.xx.xx:8888/accounts/login/?next=/some_page/
Django Version: 1.3.1
Python Version: 2.7.2
Installed Applications:
['django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.admin',
'bc_system_app',
'django.contrib.humanize']
Installed Middleware:
('django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.csrf.CsrfResponseMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware')
Traceback:
File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py" in get_response
111. response = callback(request, *callback_args, **callback_kwargs)
File "/usr/local/lib/python2.7/dist-packages/django/utils/decorators.py" in _wrapped_view
93. response = view_func(request, *args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/django/views/decorators/cache.py" in _wrapped_view_func
79. response = view_func(request, *args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/views.py" in login
35. if form.is_valid():
File "/usr/local/lib/python2.7/dist-packages/django/forms/forms.py" in is_valid
121. return self.is_bound and not bool(self.errors)
File "/usr/local/lib/python2.7/dist-packages/django/forms/forms.py" in _get_errors
112. self.full_clean()
File "/usr/local/lib/python2.7/dist-packages/django/forms/forms.py" in full_clean
268. self._clean_form()
File "/usr/local/lib/python2.7/dist-packages/django/forms/forms.py" in _clean_form
296. self.cleaned_data = self.clean()
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/forms.py" in clean
85. self.user_cache = authenticate(username=username, password=password)
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/__init__.py" in authenticate
55. user = backend.authenticate(**credentials)
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/backends.py" in authenticate
18. if user.check_password(password):
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/models.py" in check_password
275. return check_password(raw_password, self.password)
File "/usr/local/lib/python2.7/dist-packages/django/contrib/auth/models.py" in check_password
42. algo, salt, hsh = enc_password.split('$')
Exception Type: ValueError at /accounts/login/
Exception Value: too many values to unpack
Run Code Online (Sandbox Code Playgroud)
h3.*_*h3. 33
刚遇到同样的问题.
似乎在我的情况下,当创建密码时,该网站使用Django 1.4运行(由于PYTHONPATH混淆).
当我尝试使用1.3.1登录运行网站时出现此错误.然后我注意到Django版本,切换到1.4并且登录再次开始工作.
似乎密码算法在1.4中已更改:
https://docs.djangoproject.com/en/dev/releases/1.4-beta-1/#improved-password-hashing
如果您使用的是Django 1.4 alpha,那么密码可能也会被破坏(请阅读警告).
Tra*_*ear 18
最简单的解决方法是从命令行重置密码.
./manage.py changepassword <user>
Run Code Online (Sandbox Code Playgroud)
Sky*_*and 12
您可以在shell中重置密码.
from django.contrib.auth.models import User
u = User.objects.get(username="myuser")
u.set_password("mypassword")
u.save()
Run Code Online (Sandbox Code Playgroud)
当我们从1.4.X降级到测试@ h3详述的旧部署时会发生这种情况.
San*_*wal 11
是的,密码有问题.
该错误与密码加密并存储在数据库中的方式有关.从algo, salt, hsh = enc_password.split('$')追溯中的陈述可以清楚地看出.加密的密码拆分返回3个以上的值.
那么,请看一下密码加密方案和相关的.