栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

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

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

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



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/646914.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号