一尘不染

将响应发送到客户端后,在Django中执行代码

django

在我的Django应用程序中,我想跟踪响应是否已成功发送到客户端。我很清楚,HTTP之类的无连接协议中没有“防水”方式来确保客户端已接收(并显示)响应,因此这不是关键任务功能,但是我仍然想在最近的可能时间。响应将不是HTML,因此无法从客户端进行任何回调(使用Javascript或IMG标签等)。

我可以找到的“最新”钩子是在中间件列表的第一个位置添加实现process_response的自定义中间件,但是据我了解,这是在构造实际响应并将其发送给客户端之前执行的。成功发送响应后,Django中是否有任何挂钩/事件可以执行代码?


阅读 377

收藏
2020-03-31

共1个答案

一尘不染

我现在要使用的方法使用HttpResponse的子类:

from django.template import loader
from django.http import HttpResponse

# use custom response class to override HttpResponse.close()
class LogSuccessResponse(HttpResponse):

    def close(self):
        super(LogSuccessResponse, self).close()
        # do whatever you want, this is the last codepoint in request handling
        if self.status_code == 200:
            print('HttpResponse successful: %s' % self.status_code)

# this would be the view definition
def logging_view(request):
    response = LogSuccessResponse('Hello World', mimetype='text/plain')
    return response

通过阅读Django代码,我非常相信HttpResponse.close()是将代码注入到请求处理中的最新点。与上述情况相比,我不确定是否真的有这种方法可以更好地处理错误情况,因此我暂时不提问题。

与lazerscience的答案中提到的其他方法相比,我更喜欢这种方法的原因是,它可以仅在视图中设置,并且不需要安装中间件。另一方面,使用request_finished信号将不允许我访问响应对象。

2020-03-31