2-flask之路由和蓝图
------------恢复内容开始------------
一:路由
1:查询路由信息
1.1 命令行方式
flask routes
1.2 在程序中获取
在应用中的url_map属性中保存着整个Flask应用的路由映射信息,可以通过读取这个属性获取路由信息
print(app.url_map)
如果想在程序中遍历路由信息,可以采用如下方式
for rule in app.url_map.iter_rules(): print('name={} path={}'.format(rule.endpoint, rule.rule))
2:指定请求方式
在 Flask 中,定义路由其默认的请求方式为:
- GET
- OPTIONS(自带)
- HEAD(自带)
利用methods
参数可以自己指定一个接口的请求方式
@app.route("/itcast1", methods=["POST"]) def view_func_1(): return "hello world 1" @app.route("/itcast2", methods=["GET", "POST"]) def view_func_2(): return "hello world 2"
二:蓝图
1:简介
别多想,蓝图就像桑榆django中的一个app,可以划分出多个也业务单元进行独立开发
蓝图实际可以理解为是一个存储一组视图方法的容器对象,其具有如下特点:
- 一个应用(app——flask的实例化对象)可以具有多个Blueprint
- 可以将一个Blueprint注册到任何一个未使用的URL下比如 “/user”、“/goods”
- Blueprint可以单独具有自己的模板、静态文件或者其它的通用操作方法,它并不是必须要实现应用的视图和函数的
- 在一个应用初始化时,就应该要注册需要使用的Blueprint
但是一个Blueprint并不是一个完整的应用,它不能独立于应用运行,而必须要注册到某一个应用中。
2:使用方式:三步走
第一步:创建蓝图对象
user_bp=Blueprint('user',__name__)
第二步:在这个蓝图上进行操作,绑定路由,指定静态文件等
@user_bp.route('/') def user_profile(): return 'user_profile'
第三步:在app上注册蓝图
app.register_blueprint(user_bp)
3:单文件蓝图
可以将蓝图于视图放到一个文件中
from flask import Flask,Blueprint #flask 类接受一个__nmae__ 参数 app = Flask(__name__) #实例化蓝图 user_blue = Blueprint("user_",__name__) #映射函数 @user_blue.route("/blue") def blue(): return "hello blue" #装饰器的作用事将路由映射到函数中 @app.route('/') def index(): return "hello word" # app.register_blueprint(user_blue) app.register_blueprint(user_blue)
4:目录(包)蓝图
对于一个打算包含多个文件的蓝图,通常将创建蓝图对象放到Python包的__init__.py
文件中
--------- project # 工程目录 |------ main.py # 启动文件 |------ user #用户蓝图 | |--- __init__.py # 此处创建蓝图对象 | |--- passport.py | |--- profile.py | |--- ... | |------ goods # 商品蓝图 | |--- __init__.py | |--- ... |...
扩展用法
1 指定蓝图的url前缀
在应用中注册蓝图时使用url_prefix
参数指定
app.register_blueprint(user_bp, url_prefix='/user') app.register_blueprint(goods_bp, url_prefix='/goods')
2 蓝图内部静态文件
和应用对象不同,蓝图对象创建时不会默认注册静态目录的路由。需要我们在 创建时指定 static_folder 参数。
下面的示例将蓝图所在目录下的static_admin目录设置为静态目录
admin = Blueprint("admin",__name__,static_folder='static_admin') app.register_blueprint(admin,url_prefix='/admin')
现在就可以使用/admin/static_admin/<filename>
访问static_admin
目录下的静态文件了。
也可通过static_url_path
改变访问路径
admin = Blueprint("admin",__name__,static_folder='static_admin',static_url_path='/lib') app.register_blueprint(admin,url_prefix='/admin')
3 蓝图内部模板目录
蓝图对象默认的模板目录为系统的模版目录,可以在创建蓝图对象时使用 template_folder 关键字参数设置模板目录
admin = Blueprint('admin',__name__,template_folder='my_templates')
------------恢复内容结束------------