前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Werkzeug_@mapkey注解

Werkzeug_@mapkey注解

作者头像
全栈程序员站长
发布2022-11-10 16:25:02
2570
发布2022-11-10 16:25:02
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

在Python中,除了线程还有一些其他的并发方法如协程。所以在一个WSGI服务中,我们不能保证所有的请求都是以线程的形式存在。另外一种情况是当前请求复用了之前请求的线程,所以上一个请求的数据留在了当前请求的Thread Local对象中。

Werkzeug提供了自己的Local数据存储werkzeug.local。其提供了与Thread Local近似的功能,但是可以运行线程和greenlet中

代码语言:javascript
复制
from werkzeug.local import Local, LocalManager

local = Local()
local_manager = LocalManager([local])

def application(environ, start_response):
    # 绑定请求到local.request中
    local.request = request = Request(environ)
    ...

# local_manager.make_middleware确保指向the local objects的所有资源在请求后清除
application = local_manager.make_middleware(application)

local对象不能管理他们自己。local对象需要使用local manager进行管理。

1 werkzeug.local.release_local(local)

可以释放Local对象以及LocalStack对象,但是不能释放由proxy持有的数据。所有的释放Local对象的实现都是通过release_local来实现的。

代码语言:javascript
复制
>>> loc = Local()
>>> loc.foo = 42
>>> release_local(loc)
>>> hasattr(loc, 'foo')
False

2 class werkzeug.local.LocalManager(locals=None, ident_func=None)

用于管理Local对象,每当LocalManager清除(cleanup()),他就会清除在此上下文中LocalManager所管理的所有Local对象的数据。

  • locals : Local对象列表
  • ident_func: 覆盖the wrapped locals的默认验证函数

方法:

  • cleanup() 手动清除当前上下文locals中的数据。可以在请求的最后调用,也可以使用make_middleware()调用。
  • make_middleware(app) 包裹一个app使得清除操作在请求结束时自动运行
  • get_ident() 不可以覆写个这个方法。返回一个上下文标志,此上下文是local对象在内部使用的上下文。可以使用它其连接到其他的上下文到werkzeug locals。
  • middleware(func)make_middleware作用相同。但是是以装饰器的形式来使用。
代码语言:javascript
复制
@manager.middleware
def application(environ, start_response):
    ...

3 class werkzeug.local.LocalStack()

与Local相似,但是使用栈来保存对象。其内部初始化一个名字是_local的Local对象的属性,并绑定stack_local上。

代码语言:javascript
复制
>>> ls = LocalStack()
>>> ls.push(42)
>>> ls.top
42
>>> ls.push(23)
>>> ls.top
23
>>> ls.pop()
23
>>> ls.top
42

他们可以被释放通过:

  • pop(),推荐使用。在使用后pop栈中对象释放资源。
  • LocalManager
  • release_local()

当栈为空后,栈就不再绑定在当前的上下文中(栈被释放)。

方法:

  • pop() 删除栈顶元素。会返回旧的值。如果栈是空会返回None
  • push() 压入元素
  • top: property, 返回栈顶元素

4 class werkzeug.local.LocalProxy(local, name=None)

作为werkzeug local的代理,传递所有操作到一个代理对象中。不支持的传递操作有右手操作数(right handed operands)和任何形式的赋值。

创建代理

  • 像下面代码一样通过直接调用就可以创建Local或LocalStack的代理。werkzeug 0.6.1及以上版本支持。
代码语言:javascript
复制
from werkzeug.local import Local
l = Local()

# these are proxies
request = l('request')
user = l('user')


from werkzeug.local import LocalStack
_response_local = LocalStack()

# this is a proxy
response = _response_local()
  • 通过LocalProxy构造器
代码语言:javascript
复制
from werkzeug.local import Local, LocalProxy
local = Local()
request = LocalProxy(local, 'request')
代码语言:javascript
复制
session = LocalProxy(lambda: get_current_request().session)

方法:

  • _get_current_object() 返回当前的对象。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月27日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 werkzeug.local.release_local(local)
  • 2 class werkzeug.local.LocalManager(locals=None, ident_func=None)
  • 3 class werkzeug.local.LocalStack()
  • 4 class werkzeug.local.LocalProxy(local, name=None)
相关产品与服务
数据保险箱
数据保险箱(Cloud Data Coffer Service,CDCS)为您提供更高安全系数的企业核心数据存储服务。您可以通过自定义过期天数的方法删除数据,避免误删带来的损害,还可以将数据跨地域存储,防止一些不可抗因素导致的数据丢失。数据保险箱支持通过控制台、API 等多样化方式快速简单接入,实现海量数据的存储管理。您可以使用数据保险箱对文件数据进行上传、下载,最终实现数据的安全存储和提取。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档