如何在Django 1.0中执行以下(Django 0.96)调度程序挂钩?
import django.dispatch.dispatcher
def log_exception(*args, **kwds):
logging.exception('Exception in request:')
# Log errors.
django.dispatch.dispatcher.connect(
log_exception, django.core.signals.got_request_exception)
# Unregister the rollback event handler.
django.dispatch.dispatcher.disconnect(
django.db._rollback_on_exception,
django.core.signals.got_request_exception)
顺便提一下,此代码来自Google's Article on Using Django on GAE。不幸的是,Django中的调度代码在0.96和1.0之间被重写,而Google的示例不适用于Django 1.0。
当然,Django人员提供了helpful guide关于如何进行这种迁移的方法,但我现在还不足以弄明白这一点。 :O)
感谢阅读。
布赖恩
答案 0 :(得分:5)
基本区别在于您不再要求调度员将您连接到某个信号,直接询问信号。所以它看起来像这样:
from django.core.signals import got_request_exception
from django.db import _rollback_on_exception
def log_exception(*args, **kwds):
logging.exception('Exception in request:')
# Log errors.
got_request_exception.connect(log_exception)
# Unregister the rollback event handler.
_rollback_on_exception.disconnect(got_request_exception)