Django 管理员 - 'NoneType' 对象没有属性 'rindex

2 投票
4 回答
6556 浏览
提问于 2025-04-16 19:16

我正在学习《Django 1.0 网站开发》这本书。在第8章,我无法让管理应用程序正常工作。以下是我遇到的错误信息。

Environment:

Request Method: GET
Request URL: http://127.0.0.1:8000/admin/

Django Version: 1.3
Python Version: 2.6.5
Installed Applications:
['django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.sites',
 'django.contrib.comments',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django_bookmarks.bookmarks',
 'debug_toolbar',
 'django.contrib.admin',
 'django.contrib.admindocs']
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',
 'debug_toolbar.middleware.DebugToolbarMiddleware')


Traceback:
File "/usr/local/lib/python2.6/site-packages/django/core/handlers/base.py" in get_response
  101.                             request.path_info)
File "/usr/local/lib/python2.6/site-packages/django/core/urlresolvers.py" in resolve
  252.                     sub_match = pattern.resolve(new_path)
File "/usr/local/lib/python2.6/site-packages/django/core/urlresolvers.py" in resolve
  252.                     sub_match = pattern.resolve(new_path)
File "/usr/local/lib/python2.6/site-packages/django/core/urlresolvers.py" in resolve
  158.             return ResolverMatch(self.callback, args, kwargs, self.name)
File "/usr/local/lib/python2.6/site-packages/django/core/urlresolvers.py" in _get_callback
  169.             mod_name, func_name = get_mod_func(self._callback_str)
File "/usr/local/lib/python2.6/site-packages/django/core/urlresolvers.py" in get_mod_func
  113.         dot = callback.rindex('.')

Exception Type: AttributeError at /admin/
Exception Value: 'NoneType' object has no attribute 'rindex'

这是我在settings.py文件中配置的INSTALLED_APPS部分:

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.comments',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django_bookmarks.bookmarks',
    'debug_toolbar',
    # Uncomment the next line to enable the admin:
    'django.contrib.admin',
    # Uncomment the next line to enable admin documentation:
    'django.contrib.admindocs',
)

这是我的admin.py文件:

from django.contrib import admin
from bookmarks.models import *


class LinkAdmin(admin.ModelAdmin):
  pass


class TagAdmin(admin.ModelAdmin):
  pass


class BookmarkAdmin(admin.ModelAdmin):
  list_display = ('title', 'link', 'user')
  list_filter = ('user',)
  ordering = ('title',)
  search_fields = ('title',)


admin.site.register(Link, LinkAdmin)
admin.site.register(Tag, TagAdmin)
admin.site.register(Bookmark, BookmarkAdmin)

这是我的urls.py文件:

import os
from django.conf.urls.defaults import *
from django.views.generic.simple import direct_to_template
from bookmarks.views import *
from django.contrib import admin
admin.autodiscover()


site_media = os.path.join(os.path.dirname(__file__), 'site_media')


urlpatterns = patterns('',
    # Admin interface
    (r'^admin/(.*)', admin.site.root_path),

    # Browsing
    (r'^$', main_page),
    (r'^popular/$', popular_page),
    (r'^user/(\w+)/$', user_page),
    (r'^tag/([^\s]+)/$', tag_page),
    (r'^tag/$', tag_cloud_page),
    (r'^search/$', search_page),
    (r'^bookmark/(\d+)/$', bookmark_page),

    # Session management
    (r'^login/$', 'django.contrib.auth.views.login'),
    (r'^logout/$', logout_page),
    (r'^register/$', register_page),
    (r'^register/success/$', direct_to_template,
    {'template': 'registration/register_success.html'}),

    # Account management
    (r'^save/$', bookmark_save_page),
    (r'^vote/$', bookmark_vote_page),

    # Site media
    (r'^site_media/(?P<path>.*)$', 'django.views.static.serve',
    {'document_root': site_media}),

    # Ajax
    (r'^ajax/tag/autocomplete/$', ajax_tag_autocomplete),

    # Comments
    (r'^comments/', include('django.contrib.comments.urls')),

)

我尝试过从书中的源代码复制urls.py文件,但没有任何效果。我也看过其他论坛上关于属性错误的帖子,但找不到和我情况相符的例子。非常感谢你们的想法和建议。

4 个回答

0

看看这个问题:

reverse() 调用时抛出 AttributeError

可能你在 urls 元组中作为第二个项目传入的一些函数返回了 None。

9

我也遇到过这种情况,那是因为我在一个装饰器里忘记返回装饰器了:

from django.http import HttpResponseForbidden

def admin_required(func):
    def decorator(request, *args, **kwargs):
        if not request.user.is_authenticated():
            return HttpResponseForbidden()
        if not request.user.is_superuser():
            return HttpResponseForbidden()

        return func(request, *args, **kwargs)

    return decorator
3

这是:

(r'^admin/(.*)', admin.site.root_path),

导致错误的原因是,因为 admin.site.root_path 的值是 None

正确的值是:

(r'^admin/(.*)', include(admin.site.urls)),

撰写回答