应用上下文
应用 上下文
2023-06-13 09:12:34 时间
一、app对象
说明
全局应用对象
作用
- 加载配置
- 关联三方对象
- 注册蓝图
- 启动项管理
- 公共的全局的配置可以加载到该对象上
- 定义一些全局数据
需求
系统最多支持100个用户
公共配置
app.MAX_USER_NUM = <span class="hljs-number">100</span>
<span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">DefaultConfig</span><span class="hljs-params">()</span>:</span>
<span class="hljs-comment">#公共配置</span>
MAX_USER_NUM = <span class="hljs-number">3</span>
全局数据
app.USER_NUM = <span class="hljs-number">0</span>
二、current_app对象
概述
在任何视图中可以使用current_app变量访问到全局app对象
作用
app对象上的公共配置与全局数据可以在视同中通过current_app对象访问
使用
<span class="hljs-keyword">from</span> flask <span class="hljs-keyword">import</span> current_app
<span class="hljs-meta">@myApp.route("/register/", methods=["POST"])</span>
<span class="hljs-function"><span class="hljs-keyword">def</span> <span class="hljs-title">register</span><span class="hljs-params">()</span>:</span>
<span class="hljs-comment"># 假设系统最多支持100个用户</span>
<span class="hljs-comment"># 判断系统中有多少个用户,是否超过上限</span>
<span class="hljs-comment"># if app.USER_NUM == app.MAX_USER_NUM:</span>
<span class="hljs-comment"># return "用户到上限,无法注册"</span>
<span class="hljs-comment"># if current_app.USER_NUM == current_app.MAX_USER_NUM:</span>
<span class="hljs-comment"># return "用户到上限,无法注册"</span>
<span class="hljs-comment"># else:</span>
<span class="hljs-comment"># current_app.USER_NUM += 1</span>
<span class="hljs-keyword">if</span> current_app.USER_NUM == current_app.config[<span class="hljs-string">"MAX_USER_NUM"</span>]:
<span class="hljs-keyword">return</span> <span class="hljs-string">"用户到上限,无法注册"</span>
<span class="hljs-keyword">else</span>:
current_app.USER_NUM += <span class="hljs-number">1</span>
<span class="hljs-keyword">return</span> <span class="hljs-string">"获取到了post参数"</span>
三、g对象
- 说明 在一次请求响应中,提供一个全局对象g
- 作用 可以在一次处理中访问同一数据
- 注意 一般用在钩子函数中
相关文章
- Runnable和Callable源码及应用解析
- 只需要六周,这款VR应用就能帮你摆脱蜘蛛恐惧症
- 【Android 逆向】逆向修改游戏应用 ( 分析应用结构 | 定位动态库位置 | 定位动态库中的修改点 | 修改动态库 | 重打包 )
- MySQL在消息队列系统中的应用(mysql队列)
- 函数Linux 中atoi函数的应用(linuxatoi)
- 实现idea开发MySQL应用:借助MySQL驱动(ideamysql驱动)
- 与应用探索Linux分支及其应用之路(linux的分支)
- 深入探索fseek指令在Linux系统的应用与优化技巧(fseeklinux)
- Linux下KVM技术的应用(linux-kvm)
- SQL Server数据库应用及其课件学习(sqlserver课件)
- 架构SQL Server下的三层架构:开发更高效的数据应用(sqlserver 三层)
- Oracle灵活多变的应用场景(oracle使用场景)
- Oracle保留字转义破解技术的应用(oracle 保留字转义)
- Oracle中同步与异步理解和应用(oracle中同步与异步)