为什么在Django中使用线程本地变量不好?

为什么在Django中使用线程本地变量不好?,第1张

为什么在Django中使用线程本地变量不好?

我完全不同意。TLS非常有用。应谨慎使用,就像全局变量应谨慎使用一样。但是说根本不应该使用它就像说永远不应该使用全局变量一样荒谬。

例如,我将当前活动的请求存储在TLS中。这使得它可以从我的日志记录类访问,而不必通过每个接口传递请求-
包括许多根本不关心Django的接口。它使我可以从代码中的任何位置进行日志记录。记录器将输出到数据库表,如果在创建日志时碰巧一个请求处于活动状态,它将记录活动用户和所请求的内容。

如果您不希望一个线程具有修改另一个线程的TLS数据的功能,则将TLS设置为禁止此 *** 作,这可能需要使用本机TLS类。但是,我认为该论点没有说服力。如果攻击者可以执行任意Python代码作为您的后端,则您的系统已经受到致命威胁-
例如,他可以猴子修补任何内容,以便稍后以其他用户身份运行。

显然,您将需要在请求结束时清除所有TLS。在Django中,这意味着在中间件类的process_response和process_exception中清除它。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5649112.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-16
下一篇2022-12-16

发表评论

登录后才能评论

评论列表(0条)

    保存