需求分析:

当一个庞大的系统中有很多小模块,在分配路由的时候怎么处理呢?全部都堆到一个py程序中,调用@app.route? 显然这是很不明智的,因为当有几十个模块需要写路由的时候,这样程序员写着写着自己就晕掉了。同时也违背了面向对象设计原则中的控制反转原则。模块与模块之间应该不要太紧密的依赖,高级层级模块和低级层级的模块之间的依赖应该有一层抽象来实现。

Flask框架中,我们可以使用blueprint蓝图来解耦路由分配问题,实现不同业务模块之间的较为松散的依赖。

1. blueprint的实现过程

(1)在子模块views.py文件中定义蓝图

例如:为customer定义一个蓝图路由

customer = Blueprint('customer',__name__)

@customer.route()

   def  do_something():

       pass

(2)在主模块views.py文件中注册蓝图

app.register_blueprint(customer,url_prefix='/customer')

Blueprint()函数解析,Blueprint实际上是一个类

官方文档的定义:

def __init__(self, name, import_name, static_folder=None,
static_url_path=None, template_folder=None,
url_prefix=None, subdomain=None, url_defaults=None,
root_path=None):

有两个是必须填写的参数:name和import name,其余参数都是选择性的

1. name:即路由的别名,在子模块中定义的蓝图要想通过在主模块中注册使用,就需要定义一个别名

2. import name:表示模块的系统变量,用来区别是子模块还是主模块,这里必须填__name__,表示是在子模块中定义

3. url_prefix:路由前缀

例如:想到达http://myblog/article/first

/artile  即是 first前缀

4. template_folder:模板文件夹

如果想从其他模块的模板文件夹中调度模板来使用,需要使用template_folder来指明模板的搜寻路径

同样的,static_folder与static_url_path的功能与template_folder类似

5. url_defaults :默认的路由路径别名,以字典的形式保存在Blueprint类实例中。

因为保存的形式是字典,所以这个参数的值比较特殊,一定是要含有两个参数的元组形式。

例如:url_defaults=([‘so’,’so’])

有一种参数形式的路由设定方式:

@customer.route(‘/<int : any>’)

def do_something(any):

pass

路由参数在客户端输入的值时不确定的,如上面规定的int即整型数(也可以是string类型或者不设定类型)。在定义路由函数的时候,必须作为形参传入。那么如果设定了url_defaluts,则这个形参的名称就固定了,不可以为其他。例如上面的例子:url_defaults=([‘so’,’so’]),那么,形参就必须为so,而不能是any了。显然,blueprint的这个参数能够有效定义路由的具体功能,使一个路由更具体化,避免程序编写过程中随意的改动造成错误。

也就是说,一旦设定了这个参数值,那么这个路由的别名就定死了。

6. root_path:根目录的绝对路径,一般为工程项目的根目录路径

2. 关于route方法

例子:

@app.route(‘ /’ ,’index’ , index)

def index():

pass

#带引号的是endpoint,不带引号的index是路由函数名,必须要与下面定义的函数名相同

route()其实是add_url_rule()方法的实例

@app.route(‘ /’ ,’index’,index)

等价于:app.add_url_rule(‘/’,’index’, index)

也可以这样定义endpoint:

app.view_functions[‘index’] = index

官方源码:

add_url_rule(rule,endpoint=None,view_func=None,provide_automatic_options=None, **options)

参数解析:

1. rule:在浏览器输入的地址格式

2. view_func:路由函数,即开发者定义的路由

If a view_func is provided it will be registered with the endpoint.

3. endpoint:路由函数的注册别名

 

关于endpoint

endpoint相当于实际url的一个别名,在浏览器输入地址时,需要在flask后台寻找相应的路由函数(从而查找相应的资源),而在查找的过程中,不是直接用物理地址来进行硬编码的,而是通过映射成endpoint来查找。也就是说,开发者定义的每一个路由地址都有一个注册的endpoint与之对应。在客户端输入地址在后台查询资源的时候,通过这个endpoint来查找相应的路由函数。

深入理解Flask请求机制:

所有 Flask 程序都必须创建一个程序实例。 Web 服务器把接收来自客户端的所有请求路由都转交给这个实例对象处理。程序实例是 Flask 类的对象。 Flask 类的构造函数只有一个必须指定的参数,即程序主模块或包的名字,即我们经常用到的一条语句:app = Flask(__name__)。Python的 __name__ 变量会存储这些值。

另外,Flask 用蓝图 blueprint来在一个应用中或跨应用制作应用组件和支持通用的模式。通过不同的 url_prefix ,从而使用户的请求到达不同模块的 view 函数。同时,有效分离了不同模块,使得开发过程更加的清晰。

app和蓝图blueprint还有许多类方法,像route()方法一样可以作为路由函数的装饰器,对每一次请求作更精细的判别和操作,在更高效地进行数据库配置和请求操作,以及处理错误请求方面有很大的作用。下篇文章我将会写一下这方面的内容。

参考阅读:官方文档http://flask.pocoo.org/docs/dev/api/#flask.Flask.add_url_rule

例如:

before_first_request   #第一次请求的处理

before_reqeust       #注册一个函数来实现对每一个路由请求的拦截

after_request        #每一次请求之后额处理

app_context         #上下文环境

Flask路由与蓝图Blueprint的更多相关文章

  1. python 全栈开发,Day120(路由系统, 实例化Flask的参数, 蓝图(BluePrint), before_request after_request)

    昨日内容回顾 1.Flask: from flask import Flask app = Flask(__name__) # 从源码中可以看出,Flask集成的run方法是由werkzeug中的ru ...

  2. 第九篇 Flask 中的蓝图(BluePrint)

    第九篇 Flask 中的蓝图(BluePrint)   蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开怎么理解呢? ...

  3. Flask最强攻略 - 跟DragonFire学Flask - 第九篇 Flask 中的蓝图(BluePrint)

    蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开怎么理解呢? 比如说,你有一个客户管理系统,最开始的时候,只有一个查看 ...

  4. 9,Flask 中的蓝图(BluePrint)

    蓝图,听起来就是一个很宏伟的东西,在Flask中的蓝图 blueprint 也是非常宏伟的,它的作用就是将 功能 与 主服务 分开. 比如说,你有一个客户管理系统,最开始的时候,只有一个查看客户列表的 ...

  5. flask 第九篇 蓝图 Blueprint

    蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开怎么理解呢? 比如说,你有一个客户管理系统,最开始的时候,只有一个查看 ...

  6. Flask 中的蓝图(BluePrint)

    蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开 怎么理解呢? 比如说,你有一个客户管理系统,最开始的时候,只有一个查 ...

  7. day96:flask:flask-migrate&flask-session&蓝图Blueprint&蓝图的运行机制

    目录 1.flask-migrate 2.flask-session 3.蓝图:Blueprint 4.蓝图的运行机制 1.数据库迁移:flask-migrate 1.Flask的数据库迁移 在开发过 ...

  8. flask中的蓝图 Blueprint

    模块化 随着flask程序越来越复杂,我们需要对程序进行模块化的处理,之前学习过python的模块化管理,于是针对一个简单的flask程序进行模块化处理 简单来说,Blueprint 是一个存储操作方 ...

  9. Flask初学者:蓝图Blueprint

    蓝图这个名字好像就是根据单词Blueprint字面意思来,跟平常我们理解的蓝图完全挂不上钩,这里蓝图就是指Blueprint. 使用蓝图的好处是可以将不同功能作用的视图函数/类视图放到不同的模块中,可 ...

随机推荐

  1. Python 高度定制化自己的线程类和进程类代码,获取启动进程或线程方法的结果(兼容Py2和Py3)

    #encoding=utf-8 from threading import Thread from multiprocessing import Process import multiprocess ...

  2. sql server I/O硬盘交互

    一. 概述 sql server作为关系型数据库,需要进行数据存储, 那在运行中就会不断的与硬盘进行读写交互.如果读写不能正确快速的完成,就会出现性能问题以及数据库损坏问题.下面讲讲引起I/O的产生, ...

  3. 全网最详细的最新稳定OSSEC搭建部署(ossec-server(CentOS7.X)和ossec-agent(CentOS7.X))(图文详解)

    不多说,直接上干货! 前言 写在前面的话,网上能够找到一些关于ossec方面的资料,虽然很少,但是总比没有强,不过在实际的使用过程中还是会碰到许多稀奇古怪的问题.整理整理我的使用过程,就当做一篇笔记吧 ...

  4. 《HelloGitHub月刊》第 01 期

    <HelloGitHub月刊> 因为现在这个项目只有我自己做,只敢叫"月刊",希望有志同道合者,快点加入到这个项目中来!同时,如果您有更好的建议或者意见,欢迎联系我.联 ...

  5. new Date()浏览器兼容性问题

    不同浏览器有不同的差异,一般时间格式是“2018-11-13”,这种格式在Chrome下是可以正常执行的,不过在ie浏览器里面 就会变成NaN 解决方法:将时间转换成“2018/11/13” 这种格式 ...

  6. MySQL表行数查询最佳实践

    日常应用运维工作中,Dev或者db本身都需要统计表的行数,以此作为应用或者维护的一个信息参考.也许很多人会忽略select count(*) from table_name类似的sql对数据库性能的影 ...

  7. linux中gdb的使用

    断点 在代码的指定位置中断,使程序在此中断. break <function>    在进入指定函数时停住 break <linenum>    在指定行号停住. break ...

  8. python 要掌握面向对象,你得会做这些题

    1,面向对象三大特性,各有什么用处,说说你的理解. 继承:解决代码重用问题 多态:多态性,可以在不考虑对象类型的情况下而直接使用对象 封装:明确的区分内外,控制外部对隐藏属性的操作行为,隔离复杂度 2 ...

  9. 从a文件判断是否删除b文件中的行(sed示例)

    bash&shell系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html test.xml文件很大,内容结构如下: <?xml v ...

  10. Perl文件句柄引用

    目前还没介绍Perl的面向对象,所以这节内容除了几个注意点,没什么可讲的. 以前经常使用大写字母的句柄方式(即所谓的裸字文件句柄,bareword filehandle),现在可以考虑转向使用变量文件 ...