在我的Django应用程序中,我想跟踪响应是否已成功发送到客户端。我很清楚,HTTP之类的无连接协议中没有“防水”方式来确保客户端已接收(并显示)响应,因此这不是关键任务功能,但是我仍然想在最近的可能时间。响应将不是HTML,因此无法从客户端进行任何回调(使用Javascript或IMG标签等)。
我可以找到的“最新”钩子是在中间件列表的第一个位置添加实现process_response的自定义中间件,但是据我了解,这是在构造实际响应并将其发送给客户端之前执行的。成功发送响应后,Django中是否有任何挂钩/事件可以执行代码?
我现在要使用的方法使用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信号将不允许我访问响应对象。