Django v1.6调试工具栏中间件错误号.rsplit()

Jam*_*mes 11 django python-2.7 django-debug-toolbar django-1.6

我正在尝试使用django-debug-toolbar和我的django应用程序,它适用于django v1.5.但是,我正在尝试将系统迁移到django v1.6,并且当我尝试加载任何页面时它会生成以下错误.

python manage.py runserver
Validating models...

0 errors found
December 21, 2013 - 22:53:18
Django version 1.6.1, using settings 'MySite.settings'
Starting development server at http://XXX.XXX.XXX.XXX:XXXX/
Quit the server with CONTROL-C.
Internal Server Error: /
Traceback (most recent call last):
  File "/home/user/django-env/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 90, in get_response
response = middleware_method(request)
  File "/home/user/django-env/local/lib/python2.7/site-packages/debug_toolbar/middleware.py", line 45, in process_request
mod_path, func_name = func_path.rsplit('.', 1)
AttributeError: 'function' object has no attribute 'rsplit'
[21/Dec/2013 22:53:21] "GET / HTTP/1.1" 500 58172
Run Code Online (Sandbox Code Playgroud)

源代码有这个注释,但我不确定它们的含义是什么(import_by_path):

def process_request(self, request):
    # Decide whether the toolbar is active for this request.
    func_path = dt_settings.CONFIG['SHOW_TOOLBAR_CALLBACK']
    # Replace this with import_by_path in Django >= 1.6.
    mod_path, func_name = func_path.rsplit('.', 1)
    show_toolbar = getattr(import_module(mod_path), func_name)
    if not show_toolbar(request):
        return
Run Code Online (Sandbox Code Playgroud)

而且,虽然我们正在努力.知道这个消息的意思吗?

/home/user/django-env/local/lib/python2.7/site-packages/debug_toolbar/settings.py:68: DeprecationWarning: SHOW_TOOLBAR_CALLBACK is now a dotted path. Update your DEBUG_TOOLBAR_CONFIG setting.
  "DEBUG_TOOLBAR_CONFIG setting.", DeprecationWarning)
Run Code Online (Sandbox Code Playgroud)

我的settings.py:

def custom_show_toolbar(request):
    return True  # Always show toolbar, for example purposes only.

DEBUG_TOOLBAR_CONFIG = {
    'INTERCEPT_REDIRECTS': False,
    'SHOW_TOOLBAR_CALLBACK': custom_show_toolbar,
    'INSERT_BEFORE': 'div',
    'ENABLE_STACKTRACES' : True,
}
Run Code Online (Sandbox Code Playgroud)

sk1*_*k1p 22

问题由你得到的消息描述(不应该是弃用警告,而应该是a TypeError,这可能是一个错误debug_toolbar):

SHOW_TOOLBAR_​​CALLBACK现在是一个虚线路径.更新您的DEBUG_TOOLBAR_​​CONFIG设置

SHOW_TOOLBAR_CALLBACK设置曾经是一个可调用的,但现在它是一个可调用的虚线路径:一个字符串.您引用的代码尝试使用rsplit的值SHOW_TOOLBAR_CALLBACK,但由于您不能rsplit使用函数对象,因此会出现错误.

要解决此问题,请将回调放入另一个python文件中,例如your_site/toolbar_stuff.py,将设置调整为'SHOW_TOOLBAR_CALLBACK': 'your_site.toolbar_stuff.custom_show_toolbar'.您可以通过尝试shell来测试这是否有效:

from your_site.toolbar_stuff import custom_show_toolbar
Run Code Online (Sandbox Code Playgroud)

如果可行,您的新设置也应该有效.

  • 嗯......我实际上在发布之前尝试过你建议的一些事情 - 我查看了文档,但对我来说不是很清楚,错误并不清楚,代码中的注释是误导性的.我也尝试使用我的MySite.settings.custom_show_toolbar的虚线路径,但这不起作用.最终的解决方案是使用虚线路径,但要将其封装为字符串.例如,`'SHOW_TOOLBAR_​​CALLBACK':'MySite.settings.custom_show_toolbar'.或者,您可以将该功能移动到外部配置文件,但我将其保留在设置中.感谢您的反馈,它使我找到了正确的解决方案! (3认同)