【Flask】 路由入门

【Flask】 路由入门,第1张

为了给 URL 增加变量的部分,你需要把一些特定的字段标记成

这些特定的字段将作为参数传入到你的函数中,当然也可以指定一个可选的转换器通过规则

将变量值转换为特定的数据类型。

转换器的主要类型如下:

| 类型 | 含义 |

| — | — |

| string | 默认的数据类型,接受没有任何斜杠“/”的字符串 |

| int | 接受整型 |

| float | 接受浮点类型 |

| path | 和 string 类似,但是接受斜杠“/” |

| uuid | 只接受 uuid 字符串 |

from flask import Flask

app = Flask(name)

String 类型

@app.route(‘/user/’)

def show_user(username):

return ‘User: {}’.format(username)

int 类型

@app.route(‘/page/int:id’)

def show_page(id):

return ‘Page: {}’.format(id)

path 类型

@app.route(‘/path/path:subpath’)

def show_path(subpath):

return ‘Path: {}’.format(subpath)


[](()唯一URLs/重定向行为

===========================================================================

Flask 的 URL 规则是基于 Werkzeug 的 routing 模块

该模块背后的思路是基于 Apache 和早期的 HTTP 服务器定下先例确保优雅和唯一的 URL

以这两个规则为例

@app.route(‘/projects/’)

def projects():

return ‘The project page’

@app.route(‘/about’)

def about():

return ‘The about page’

虽然它们看起来确实相似,但它们结尾斜线的使用在 URL 定义中不同。

  • 第一种情况

规范的 URL 指向 projects 尾端有一个斜线 / 。这种感觉很像在文件系统中的文件夹。访问一个结尾不带斜线的 URL 会被 Flask 重定向到带斜线的规范 URL 去。

当访问 https://xxx/projects/ 时,页面会显示 The project page

  • 第二种情况

URL 结尾不带斜线,类似 UNIX-like 系统下的文件的路径名。此时如果访问结尾带斜线的 URL 会产生一个 404 “Not Found” 错误。

当访问 https://xxx/about 时,页面会显示 The about page

但是当访问 https://xxx/about/ 时,页面就会报错 Not Found

当用户访问页面忘记结尾斜线时,这个行为允许关联的 URL 继续工作,并且与 Apache 和其它的服务器的行为一致,反之则不行,因此在代码的 URL 设置时斜线只可多写不可少写;

另外,URL 会保持唯一,有助于避免搜索引擎索引同一个页面两次。


[](()HTTP方法

=====================================================================

HTTP (也就是 Web 应用协议) 有不同的方法来访问 URLs 。

默认情况下,路由只会响应 GET 请求,但是能够通过给 route() 装饰器提供 methods 参数来改变。

from flask import Flask, request

app = Flask(name)

@app.route(‘/login’, methods=[‘GET’, ‘POST’])

def login():

if request.method == ‘GET’:

return “–注册页面–”

else:

return “–注册API–”

如果使用 GET 方法,HEAD 方法将会自动添加进来。你不必处理它们。

也能确保 HEAD 请求会按照 HTTP RFC (文档在 HTTP 协议里面描述) 要求来处理,因此你完全可以忽略这部分 HTTP 规范。

同样地,自从 Flask 0.6 后,OPTIONS 方法也能自动为你处理。

HTTP方法(通常也称为“谓词”)告诉服务器客户端想要对请求的页面做什么。

下面这些方法是比较常见的:

  • GET

浏览器通知服务器只获取页面上的信息并且发送回来。这可能是最常用的方法。

  • POST

浏览器通知服务器它要在 URL 上提交一些信息,服务器必须保证数据被存储且只存储一次。这是 HTML 表单通常发送数据到服务器的方法。

  • PUT

同 POST 类似,但是服务器可能触发了多次存储过程,多次覆盖掉旧值。

现在你就会问这有什么用,有许多理由需要如此去做。

考虑下在传输过程中连接丢失:在这种情况下浏览器和服务器之间的 《大厂前端面试题解析+Web核心总结学习笔记+企业项目实战源码+最新高清讲解视频》无偿开源 徽信搜索公众号【编程进阶路】 系统可能安全地第二次接收请求,而不破坏其它东西。该过程 *** 作 POST 方法是不可能实现的,因为它只会被触发一次。

  • HEAD

浏览器告诉服务器获取信息,但是只对头信息感兴趣,不需要整个页面的内容。

应用应该处理起来像接收到一个 GET 请求但是不传递实际内容。在 Flask 中你完全不需要处理它,底层的 Werkzeug 库会为你处理的。

  • DELETE

移除给定位置的信息。

  • OPTIONS

给客户端提供一个快速的途径来指出这个 URL 支持哪些 HTTP 方法。从 Flask 0.6 开始,自动实现了该功能。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/789075.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-05
下一篇 2022-05-05

发表评论

登录后才能评论

评论列表(0条)

保存