Inside Flask - app.py - 1

除 werkzeug 和 jinja2 等依赖库外,app.py 是在 Flask 的 __init__.py 中导入的第一个 Flask 自身的模块。 app.py 的注释中已明确说明这个模块的作用:

flask.app
~~~~~~~~~ This module implements the central WSGI application object.

依赖分析

在这个模块中,导入了 Flask 中的其它工具模块,并组合起来实现所需的功能,包括:

  1. 内置模块

    app.py 导入了以下的内置模块

     import os
    import sys
    from threading import Lock
    from datetime import timedelta
    from itertools import chain
    from functools import update_wrapper

    线程锁 Lock 用在日志初始化(行 40 ,579)和第一次请求时回调用已注册在 before_first_request_funcs 的函数(行 499 ,1492)

    timedelta 用来处理 Flask 中和时间相关的配置信息(行 220),一般以秒为单位。

    chain 处理可迭代变量,如多个函数列表的合并等(行 713)。

    update_wrapper 是个函数装饰器工具,让函数看起来过像是原来的函数,可跳转到代码看看它的实现。

  2. 依赖库模块

    从 werkzeug 导入了一些简单的类工具

     from werkzeug.datastructures import ImmutableDict
    from werkzeug.routing import Map, Rule, RequestRedirect, BuildError
    from werkzeug.exceptions import HTTPException, InternalServerError, \
    MethodNotAllowed, BadRequest

    后面在涉及到代码时再分析。

  3. Flask 其它工具模块

    基本上把其它的工具模块都导了进来,并整合到 Flask 类中,这些后面涉及到时再分析。

代码分析

这个模块中包含 _make_timedelta setupmethod Flask 3 个 object。

  1. _make_timedelta

    这只是一个简单的工具函数,把数字当作秒数,并转换为 datetime.timedelta

  2. setupmethod

    它是个装饰器,用来标记一个函数是 setup 函数。为了提高代码的规范性,它要求被装饰的函数,如 register_blueprint 等,只允许未有任务请求前调用。在 debug 状态下,如果已经有 URL 被请求过,此时再执行这类函数,就会抛出异常。

    它的作用在于,提示开发者,别做出在类似于在飞机飞行途中更换引擎的危险行为。但是如果非要这样做,那么它也没有阻止你,在非 debug 下调用这类 setup 函数并不会抛出异常,但记住,后果自负。

  3. Flask

    Flask 类可能是 Flask 里面最大最复杂的类。 Flask 类的代码从 66 行到 1842 行,一共 1776 行。整个 Flask 的源代码才 5374 行,而 Flask 类已经占了 1/3 !

    但不要担心,在去掉了注释和 docstring 后,统计出来的代码并不多,只有 794 行!! ::

     sed -e '/^[[:space:]]*#/d' -e '/""".*"""/d' \
    -e '/"""/,/"""/d' app.py | wc -l

    真让人激动,这 794 行的代码里隐藏着怎样的秘密

    Flask 类里面的方法较多,大体上分成几类:

    1. 配置处理
    2. 模板处理
    3. 会话管理
    4. 路由
    5. blueprint 扩展
    6. 回调函数管理
    7. 上下文管理
    8. 错误和异常处理
    9. wsgi 和请求分发
    10. 测试支持

    后续逐个分析相关的功能的设计。

Inside Flask - app.py - 1的更多相关文章

  1. Inside Flask - app.py - 2

    Inside Flask - app.py - 2 Flask 初始化参数 Flass 类是 Flask 框架的核心,一个 flask 对象处理视图函数注册.URL规则.模板配置.参数设置等等. 一般 ...

  2. Flask源码阅读-第四篇(flask\app.py)

    flask.app该模块2000多行代码,主要完成应用的配置.初始化.蓝图注册.请求装饰器定义.应用的启动和监听,其中以下方法可以重点品读和关注 def setupmethod(f): @setupm ...

  3. Inside Flask - 配置的实现

    Inside Flask - 配置的实现 flask 的配置对象 app.config 本身使用很简单,无非就是以字典的形式使用,而它的实现,本身就是以字典的形式的. 在 flask/config.p ...

  4. Inside Flask - globals 全局变量(对象代理)

    Inside Flask - globals 全局变量(对象代理) 框架是一个容器,在框架内编程,一般是要遵守框架的约定和使用模式.通常这样的模式是 IoC,即由框架调用用户的代码,而不是用户调用框架 ...

  5. Inside Flask - flask.__init__.py 和核心组件

    Inside Flask - flask.__init__.py 和核心组件 简单的示例 首先看看一个简单的示例.使用 Flask ,通常是从 flask 模块导入 Flask . request 等 ...

  6. Flask - app.debug=True,python manage.py和export FLASK_DEBUG=True,flask run的不同。

    TL;DR,可以直接看下面的总结 问题1:为什么app.config['DEBUG'] = True,然后flask run并没有开启debugger和reloading,而直接运行脚本(python ...

  7. Inside Flask - json 处理

    Inside Flask - json 处理 在处理 web api 时,json 是非常好用的数据交换格式,它结构简单,基本上各种主流的编程语言都有良好的支持工具. flask 中处理 json 时 ...

  8. Inside Flask - signal 信号机制

    Inside Flask - signal 信号机制 singal 在平常的 flask web 开发过程中较少接触到,但对于使用 flask 进行框架级别的开发时,则必须了解相关的工作机制.flas ...

  9. Inside Flask - flask 扩展加载过程

    Inside Flask - flask 扩展加载过程 flask 扩展(插件)通常是以 flask_<扩展名字> 为扩展的 python 包名,而使用时,可用 import flask. ...

随机推荐

  1. 记linux终端下怎样退出>

    敲命令时候,敲错了,进入了>的提示下,怎么也退不出了.查了资料是按ctrl+c或者ctr+d都能退出

  2. jdk+myeclipse配置安装相关步骤

    1.JDK的安装JDK  版本:7u25  安装路径:c:\java(注意:装不装公共jre都可,自己可以选择安装到哪里)环境变量配置:(1)JAVA_HOME:C:\Java(就是你安装jdk的目录 ...

  3. PHP多重判断删除文件函数

    <?function delete_file($file) {     if (file_exists($file))     {         $delete = chmod ($file, ...

  4. 什么是java 键值对

    所谓键值对,你可以查看jdk文档,找MAP接口,它的实现类都是键值对的形式保存数据的 键:就是你存的值的编号值:就是你要存放的数据

  5. 【收集】JAVA多文件 上传文件接口代码 -兼容app

    原文:http://www.verydemo.com/demo_c143_i23854.html 我们在 multifile 中可以很容易的发现如何使用,这里就简单说说了,首先在页面上我们需要有这样几 ...

  6. PHP 设计模式 笔记与总结(1)命名空间 与 类的自动载入

    ① PHP 面向对象高级特性 ② 11 种 PHP 设计模式 ③ PSR-0,Composer,Phar 等最流行的技术 目标是掌握 PHP 各类设计模式,以及具备设计纯面向对象框架和系统的能力 [命 ...

  7. DirectX基础学习系列8 渐进网格以及外接体

    1 IUnknown--> ID3DXBUFFER D3D泛型接口: GetBufferPointer Retrieves a pointer to the data in the buffer ...

  8. LR中的C语言问题

    今天在调试LR的脚本(C)时遇到了几个甚是头痛得问题,下面简单总结下: 1.首先LR中的C编译器遵循C90标准,规定在一个函数中,变量定义必须放在所有的执行语句之前!一旦在运行语句之间再有定义的话,会 ...

  9. (转)maven 配置在eclipse中

    maven3 下载配置 下载地址 http://maven.apache.org/download.cgi 在线文档 http://maven.apache.org/ref/3.0.5/ 安装 一.安 ...

  10. nginx 配置多个二级域名

    server { server_name domain.com www.domain.com *.domain.com ; set $subdomain ''; if ($host ~* (\b(?! ...