flask 蓝图(Blueprint)路由详解

Blueprint

模块化

随着flask程序越来越复杂,我们需要对程序进行模块化的处理,针对一个简单的flask程序进行模块化处理

举例来说:

我们有一个博客程序,前台界面需要的路由为:首页,列表,详情等页面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
源程序app.py文件:
from flask import Flask
 
app = Flask(__name__)
 
@app .route( '/' )
def index():
     return 'index'
 
@app .route( '/list' )
def list ():
     return 'list'
 
@app .route( '/detail' )
def detail():
     return 'detail'
 
if __name__ = = '__main__' :
     app.run()

如果博主需要编辑博客,要进入后台进行处理:后台主页,编辑,创建,发布博客

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
改进后程序:
from flask import Flask
 
app = Flask(__name__)
 
@app .route( '/' )
def index():
     return 'index'
 
@app .route( '/list' )
def list ():
     return 'list'
 
@app .route( '/detail' )
def detail():
     return 'detail'
 
@app .route( '/' )
def admin_home():
     return 'admin_home'
 
@app .route( '/new' )
def new():
     return 'new'
 
@app .route( '/edit' )
def edit():
     return 'edit'
 
@app .route( '/publish' )
def publish():
     return 'publish'
 
if __name__ = = '__main__' :
     app.run()

这样就使得我们在一个py文件中写入了很多路由,将来维护代码会非常麻烦,此时,同学们就考虑到了模块化的处理方式,将admin相关的路由写到一个admin.py文件中,那我们就顺着这个思路走下去

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
修改后的代码:
app.py
from flask import Flask
 
app = Flask(__name__)
 
@app .route( '/' )
def index():
     return 'index'
 
@app .route( '/list' )
def list ():
     return 'list'
 
@app .route( '/detail' )
def detail():
     return 'detail'
 
if __name__ = = '__main__' :
     app.run()
 
admin.py
 
@app .route( '/' )
def admin_home():
     return 'admin_home'
 
@app .route( '/new' )
def new():
     return 'new'
 
@app .route( '/edit' )
def edit():
     return 'edit'
 
@app .route( '/publish' )
def publish():
     return 'publish'

发现app.py文件中的app直接报错,代码无法继续写下去,所以在flask程序中,使用传统的模块化是行不通的,需要flask提供一个特有的模块化处理方式,flask内置了一个模块化处理的类,即Blueprint

Blueprint概念

简单来说,Blueprint 是一个存储操作方法的容器,这些操作在这个Blueprint 被注册到一个应用之后就可以被调用,Flask 可以通过Blueprint来组织URL以及处理请求。

Flask使用Blueprint让应用实现模块化,在Flask中,Blueprint具有如下属性:

  • 一个应用可以具有多个Blueprint
  • 可以将一个Blueprint注册到任何一个未使用的URL下比如 “/”、“/sample”或者子域名
  • 在一个应用中,一个模块可以注册多次
  • Blueprint可以单独具有自己的模板、静态文件或者其它的通用操作方法,它并不是必须要实现应用的视图和函数的
  • 在一个应用初始化时,就应该要注册需要使用的Blueprint

但是一个Blueprint并不是一个完整的应用,它不能独立于应用运行,而必须要注册到某一个应用中。

初识蓝图

蓝图/Blueprint对象用起来和一个应用/Flask对象差不多,最大的区别在于一个 蓝图对象没有办法独立运行,必须将它注册到一个应用对象上才能生效

使用蓝图可以分为三个步骤

1,创建一个蓝图对象

?
1
admin = Blueprint( 'admin' ,__name__) 

2,在这个蓝图对象上进行操作,注册路由,指定静态文件夹,注册模版过滤器

?
1
2
3
@admin .route( '/' )
def admin_home():
     return 'admin_home'

3,在应用对象上注册这个蓝图对象

?
1
app.register_blueprint(admin,url\_prefix = '/admin' )

当这个应用启动后,通过/admin/可以访问到蓝图中定义的视图函数

运行机制

  • 蓝图是保存了一组将来可以在应用对象上执行的操作,注册路由就是一种操作
  • 当在应用对象上调用 route 装饰器注册路由时,这个操作将修改对象的url_map路由表
  • 然而,蓝图对象根本没有路由表,当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表defered_functions中添加了一个项
  • 当执行应用对象的 register_blueprint() 方法时,应用对象将从蓝图对象的 defered_functions 列表中取出每一项,并以自身作为参数执行该匿名函数,即调用应用对象的 add_url_rule() 方法,这将真正的修改应用对象的路由表

蓝图的url前缀

  • 当我们在应用对象上注册一个蓝图时,可以指定一个url_prefix关键字参数(这个参数默认是/)
  • 在应用最终的路由表 url_map中,在蓝图上注册的路由URL自动被加上了这个前缀,这个可以保证在多个蓝图中使用相同的URL规则而不会最终引起冲突,只要在注册蓝图时将不同的蓝图挂接到不同的自路径即可

  • url_for

url_for('admin.index') # /admin/

注册静态路由

  和应用对象不同,蓝图对象创建时不会默认注册静态目录的路由。需要我们在 创建时指定 static_folder 参数。

下面的示例将蓝图所在目录下的static_admin目录设置为静态目录

?
1
2
admin = Blueprint( "admin" ,__name__,static_folder = 'static_admin' )
app.register_blueprint(admin,url_prefix = '/admin' )

  现在就可以使用/admin/static_admin/ 访问static_admin目录下的静态文件了 定制静态目录URL规则 :可以在创建蓝图对象时使用 static_url_path 来改变静态目录的路由。下面的示例将为 static_admin 文件夹的路由设置为 /lib

?
1
2
admin = Blueprint( "admin" ,__name__,static_folder = 'static_admin' ,static_url_path = '/lib' )
app.register_blueprint(admin,url_prefix = '/admin' )

设置模版目录

  蓝图对象默认的模板目录为系统的模版目录,可以在创建蓝图对象时使用 template_folder 关键字参数设置模板目录

?
1
admin = Blueprint( 'admin' ,__name__,template_folder = 'my_templates' )

  注:如果在 templates 中存在和 my_templates 同名文件,则系统会优先使用 templates 中的文件 参考链接:https://stackoverflow.com/questions/7974771/flask-blueprint-template-folder

转载:https://www.cnblogs.com/wf-skylark/p/9306789.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask 是一个轻量级的 Web 框架,它提供了一种易于使用的方式来构建 Web 应用程序。下面是 Flask 中一些常用的概念: 1. Flask app:Flask app 是一个 Flask 应用程序的实例,它封装了所有 Flask 相关的配置、路由、视图函数等。 2. Flask 蓝图Flask 蓝图是一种将 Flask 应用程序分成更小、更易于管理的部分的方式。每个蓝图都可以定义自己的路由、视图函数、模板等。 3. Flask 模板:Flask 模板是一种将动态数据与静态 HTML 页面结合起来的方式。Flask 使用 Jinja2 模板引擎,开发者可以使用模板语言来生成动态内容。 4. Flask 路由Flask 路由用于将 URL 映射到视图函数。开发者可以使用 Flask路由装饰器来定义路由,例如:@app.route('/index')。 下面是一个简单的 Flask 应用程序示例,包括定义 Flask app、使用蓝图、定义模板和路由: ```python from flask import Flask, Blueprint, render_template app = Flask(__name__) # 定义蓝图 bp = Blueprint('bp', __name__) # 定义模板 @app.route('/index') def index(): return render_template('index.html') # 定义路由 @bp.route('/hello') def hello(): return 'Hello, World!' # 注册蓝图 app.register_blueprint(bp, url_prefix='/bp') if __name__ == '__main__': app.run() ``` 这个例子中,首先定义了一个 Flask app,然后定义了一个蓝图 bp,接着定义了一个模板 index.html 和一个路由 /hello,最后将蓝图注册到 app 中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值