Flask路由

103 阅读2分钟

路由

现代 web 应用都使用有意义的 URL ,这样有助于用户记忆,网页会更得到用户的青睐,提高回头率

使用 route() 装饰器来把函数绑定到 URL

@app.route('/path/<int:uid>',methods=["GET"],endpoint="name") 

动态路由

通过把 URL 的一部分标记为 <variable_name> 就可以在 URL 中添加变量。标记的部分会作为关键字参数传递给视图函数,作为视图函数的参数

通过使用 converter:variable_name ,可以选择性的加上一个转换器,为变量指定规则,类似Django的路由传参

@app.route('/test/<username>')
def test(username):
    return 'url: %s' % username

转换器

转换器类型解释
int正整数
float接受正浮点数
path类似 string ,但可以包含斜杠
uuid接受 UUID 字符串
string除了斜杠以外的字符串(默认值)

路由命名

flask路由系统支持和django一样的路由命名方式,常见写法通过在@app.route装饰器部分使用endpoint即可完成

注意:如果没有设置endpoint参数,那么默认以函数名为路由命名

from flask import redirect
@app.route('/test', endpoint="test")
def test():
    # 反向解析并重定向
    return redirect(url_for("home"))
    
@app.route('/home', endpoint="home")
def home():
    return "home"

**url_for**用来解析路由命名,生成对应的路由

如果解析的路由命名具有参数,像下面这样,可以在url_for参数后使用不定长字典传参方式传递连接的动态参数

from flask import redirect
@app.route('/test', endpoint="test")
def test():
    # 反向解析并重定向
    return redirect(url_for("home",id=1)) # look here
    
@app.route('/home/<id>', endpoint="home")
def home():
    return "home"

请求控制

还可以通过在路由装饰器上定义methods参数控制该视图可以被访问的请求方式

@app.route('/path/<int:uid>',methods=["GET","POST"],endpoint="views")
def views(uid):
    if request.method == "GET":
        ...
    if request.method == "POST":
        ...

路由本质

app.route装饰器方法源码如下

def route(self, rule, **options):
    def decorator(f):
        endpoint = options.pop("endpoint", None)
        self.add_url_rule(rule, endpoint, f, **options)
        return f
​
    return decorator

装饰器的闭包方法调用了add_url_rule方法进行视图的路由映射,所以一个视图写完之后,不光可以通过装饰器,也可以直接使用该方法进行路由映射定义

def views():
    ...
app.add_url_rule("/path","name",views, methods=["GET", "POST"])

add_url_rule(rule, endpoint, view_func,
             methods=["GET", "POST"], defaults = {'k': 'v'}, 
             strict_slashes=True,), redirect_to="https://baidu.com"
'''
rule: URL规则
view_func: 视图函数名称
endpoint: 路由命名
methods: 允许请求的方式
strict_slashes: 路由末尾的斜杠检查是否严格
defaults: 默认值, 当URL中无参数,函数需要参数时,使用defaults = {'k': 'v'}
redirect_to: 直接重定向
strict_slashes: 该参数是用来设置,我们的路由是否为严格模式,False是非严格模式,True严格,默认是严格
'''