Flask 中的路由系统
基本用法
Django的路由系统url集中在一起,而Flask的路由系统以装饰器的形式装饰在视图上如:
@app.route("/",methods=["GET","POST"])
@app.route() 装饰器中的参数
第一个位置参数代表路由地址
methods : 当前 url 地址,允许访问的请求方式
以下例子包含部分request的方法取值
@app.route('/get_request', methods=['GET', 'POST']) def login(): if request.method == 'GET': print(request.args.get('id')) # url中的数据 print(request.args.to_dict()) # 杂项 print('1>>>',request.url) # 整个访问地址 print('2>>>',request.values) # args和from所有的数据 这儿有深坑,不要用to_dict, print('3>>>',request.path) # 路由地址 print('4>>>',request.base_url) # 最基础的url print('5>>>',request.host) # 主机地址 print('6>>>',request.host_url) ## 两个特殊值 print(request.json) # 请求头:Content-type:application/json print(request.data) # 当请求头 不被认可的情况 存放原始数据 b"" + Content-type:application/json 也会保留原始数据 return render_template('login.html') else: print(request.form.get('username')) # FormDate中的数据 print(request.form.to_dict()) # 以字典形式打印出来 return request.form.get('username', '错误')
endpoint : 反向url地址
from flask import url_for @app.route("/info", methods=["GET", "POST"], endpoint="r_info") def student_info(): print(url_for("r_info")) # /info stu_id = int(request.args["id"]) return f"Hello {stu_id}" # Python3.6的新特性 f"{变量名}"
endpoint 默认是视图函数名 ,url_for 反向生成URL地址 ——可以解决视图函数重名:
@app.route("/detail",methods=["GET","POST"]) # route(detail) -> nei_func --> detail @wai_func # wai_func(detail) -> nei_func --> deltail def detail(): return render_template("detail.html") @app.route("/detail2",methods=["GET","POST"]) # route(detail) -> nei_func --> detail @wai_func def detail2(): return render_template("detail.html")
上面例子中,运行会报这样的错误
这是因为装饰器的机制会使两个路由都指向装饰器的内层函数nei_func ,就会出现函数重名的报错
如果加上endpoint就不会有这样的问题了
@app.route("/detail",methods=["GET","POST"],endpoint='detil') # route(detail) -> nei_func --> detail @wai_func # wai_func(detail) -> nei_func --> deltail def detail(): return render_template("detail.html") @app.route("/detail2",methods=["GET","POST"],endpoint='detil2') # route(detail) -> nei_func --> detail @wai_func def detail2(): return render_template("detail.html")
项目已经成功运行了
defaults : 视图函数的参数默认值{"nid":1}
传递默认参数 defaults={"nid":1} def index(nid)
strict_slashes
url地址结尾符"/"的控制 False : 无论结尾 "/" 是否存在均可以访问 , True : 结尾必须不能是 "/"
是否严格遵守URL地址规则 == True 在地址末尾不可以出现 / 反之可以
redirect_to : url地址重定向
永久重定向 "/infos" http 状态码 - 301 不走被装饰的视图
# 访问地址 : /info 浏览器跳转至 /infos @app03.route("/info", strict_slashes=True, redirect_to="/infos") def student_info(): return "Hello I'm info" @app03.route("/infos", strict_slashes=False) def student_infos(): return "Hello I'm infos"
subdomain
子域名配置 必须和 app中的 SERVER_NAME 联动
子域名前缀 subdomian="DragonFire" 这样写可以得到 DragonFire.zwq.com 前提是app.config["SERVER_NAME"] = "zwq.com"
app.config["SERVER_NAME"] = "zwq.com" @app.route("/info",subdomain="DragonFire") def student_info(): return "Hello Old boy info" # 访问地址为: DragonFire.zwq.com/info
动态参数路由
from flask import url_for # 访问地址 : http://127.0.0.1:5000/info/1 @app.route("/info/<int:nid>", methods=["GET", "POST"], endpoint="r_info") def student_info(nid): print(url_for("r_info",nid=2)) # /info/2 return f"Hello {nid}"
<int:nid> 就是在url后定义一个参数接收
但是这种动态参数路由,在url_for的时候,一定要将动态参数名+参数值添加进去,否则会抛出参数错误的异常
添加路由的另一种方法
通过分析源码得知添加路由本质上就是这种方法:add_url_rule("/login",view_func=login)
所以可以直接通过add_url_rule()添加路由
def login(): print(url_for("my_home_page")) # print(url_for("index2")) return "" app.add_url_rule("/login",view_func=login) # 第二种添加路由的方式,本质不变