美文网首页
Flask - 04 路由

Flask - 04 路由

作者: Lisa_Guo | 来源:发表于2019-11-20 13:47 被阅读0次

现代 web 应用都使用有意义的 URL ,这样有助于用户记忆,网页会更得到用户的青睐, 提高回头率。
Flask使用route()装饰器来把函数绑定到 URL。

有以下三种方式定义路由规则:

  1. route()装饰器
  2. add_url_rule()函数
  3. 底层Werkzeug的url_map函数

一、route()装饰器

route(rule, options)装饰器接受两个参数,第一个为路由匹配规则。分以下几种

1. 简单URL

指定一个字符串作为url

@app.route('/')
def index():
    return 'Index Page'

@app.route('/hello')
def hello():
    return 'Hello, World'

2. 含变量的URL

url含有变量标记<variable_name>, 标记部分会作为参数传给函数

@app.route('/user/<username>')
def show_user_profile(username):
    # show the user profile for that user
    return 'User %s' % escape(username)

3. 含转换器的URL

为变量增加转换器作为规则<converter:variable_name>

@app.route('/post/<int:post_id>')
def show_post(post_id):
    # show the post with the given id, the id is an integer
    return 'Post %d' % post_id

@app.route('/path/<path:subpath>')
def show_subpath(subpath):
    # show the subpath after /path/
    return 'Subpath %s' % escape(subpath)

转换器(converter)类型有:

描述
string (缺省值)接受任何不包含斜杠的文本
int 接受正整数
float 接受正浮点数
path 类似string,但可以包含斜杠
uuid UUID字符串

4 URL中斜杠(/)的重定向

使用route装饰器定义url时,字符串的末尾有无斜杠意义不同

@app.route('/projects/')
def projects():
    return 'The project page'

访问如上URL时如果末尾不带斜杠,Flask 会自动进行重定向,帮你在尾部加上一个斜杠。
所以,访问http://xxx/projects时会自动重定向到末尾带斜杠的url http://xxx/projects/,从而匹配projects函数进行响应

@app.route('/about')
def about():
    return 'The about page'

访问如上一个url,必须不带斜杠。如果带斜杠则会提示404。故访问http://xxx/about/ 则会报404

5. 多路由

同一个函数可以由多个route装饰,并可设置默认路由

@app.route('/users/', defaults={'page': 1})
@app.route('/users/page/<int:page>')
def show_users(page):
   print('show users in page ' , page)

如果用户访问/users/,则访问第一页。/users/page/n则访问第N页
注意,默认的路由只能接受get请求

4. 带HTTP的路由

route(rule, option)第二个参数可以指定该方法接受的HTTP操作,默认是get请求

@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        return do_the_login()
    else:
        return show_the_login_form()

5. 构建URL

url_for(function)拥有获取某个函数对应的url

from flask import Flask, redirect, url_for,
app = Flask(__name__)

@app.route('/task/')
def get_task(id):
    return "task"

# 必须有context时url_for才起作用,此处仅为demo
with app.test_request_context():
    print(url_for('get_task')) # 输出'/task/'

当HTML页面需要导航到某个url时,可用url_for生成一个url字符串

<a href={{ url_for('get_task', id='no1') }}>获取task</a>

# 输出
<a href='/task/no1'>获取task</a>

也可以为route()传入endpoint为url传入别名,这样当使用url_for()时参数就是这个别名而非原来的函数名

@app.route(‘/‘,endpoint=‘index‘)
def hello_world():
    return ‘hello world‘

url_for('index')

参数
url_for()也可以附带一些参数,比如想要完整的URL,可以设置_external为Ture:

  • endpoint
    URL的端点(即函数的名字)
  • values
    URL的变量参数
  • _external
    如果设置为True,则生成一个绝对路径URL
  • _scheme
    一个字符串指定所需的URL方案。_external参数必须设置为True,不然会抛出ValueError。
  • _anchor
    如果设置了这个则给URL添加一个mao
  • _method
    如果设置这个则显示地调用这个HTTP方法

url('task', _external=True, id=1),构建出的url是http://localhost/task/1

二、add_url_rule

可以通过此函数动态绑定一个url与一个函数。route()装饰器内部实际上也是调用这个函数。

@app.route('/')
def index():
    pass

# Is equivalent to the following:

def get_task():
    pass
app.add_url_rule('/', 'task', get_task)

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

  • rule: 设置的url
  • endpoint: url设置的别名,可省略
  • view_func: 函数名

相关文章

  • Flask - 04 路由

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

  • Python学习

    python-flask框架学习(二) 1、回顾Flask 2、Flask route路由 2.1、静态路由 ap...

  • 深入理解Flask路由的实现机制

    本篇介绍 Flask 路由的基本用法,并且通过部分源代码深入浅出阐述 Flask 路由的实现机制。 路由的基本用法...

  • Flask路由系统

    通常有3种定义路由函数的方法: 使用flask.Flask.route() 修饰器。 使用flask.Flask....

  • Sanic学习(二) - 基础

    路由 路由方面其实和flask很类似,flask不熟悉的话可以去看看我前面关于flask的基础教程 但是这里有一点...

  • Flask结合dropzone实现大文件分片传输

    upload.html flask后端路由

  • Python操作三大数据库(3)-实战Flask-ORM

    flask入门 安装 Flask 更多请查看 Flask帮助文档>> 快速入门 建立模型 建立Form验证 建立路由

  • 关于flask路由的思考

    flask路由 在使用flask时,我们设置路由的方式通常为: 问题来了, 我们并没有执行定义的函数,那么app....

  • Flask RESTFUL文档

    Flask文档 1. 快速入门(Quickstart) 1.1 最小的Flask应用 1.2 路由(Routing...

  • Flask教程

    Flask文档 1. 快速入门(Quickstart) 1.1 最小的Flask应用 1.2 路由(Routing...

网友评论

      本文标题:Flask - 04 路由

      本文链接:https://www.haomeiwen.com/subject/adgnictx.html