路由介绍
现代 Web 应用程序使用有意义的 URLs 去帮助用户。
如果一个网站使用有意义的 URL 能够让用户记住并且直接访问这个页面,那么用户会更有可能再一次访问该网站。
正如上面所说,route
装饰器是用于把一个函数绑定到一个 URL 上
接下来我们实现:
- 访问根目录 ‘
/
’ ,返回 ’Root directory
’ - 访问 ‘
/hello`' ,返回 '`Hello, World!
’
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return 'Index Page'
@app.route('/hello')
def hello():
return 'Hello, World!'
终端执行
export FLASK_APP=hello.py
export FLASK_ENV=development
flask run
这样就实现了通过访问不同的 URL 地址从而响应不同的页面。
不仅如此!你可以动态地构造 URL 的特定部分,也可以在一个函数上绑定多个不同的规则。
变量规则
为了给 URL 增加变量的部分,你需要把一些特定的字段标记成 <variable_name>
。
这些特定的字段将作为参数传入到你的函数中,当然也可以指定一个可选的转换器通过规则
<converter:variable_name>
将变量值转换为特定的数据类型。
转换器的主要类型如下:
类型 | 含义 |
---|---|
string | 默认的数据类型,接受没有任何斜杠“/”的字符串 |
int | 接受整型 |
float | 接受浮点类型 |
path | 和 string 类似,但是接受斜杠“/” |
uuid | 只接受 uuid 字符串 |
from flask import Flask
app = Flask(__name__)
# String 类型
@app.route('/user/<username>')
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 类似,但是服务器可能触发了多次存储过程,多次覆盖掉旧值。
现在你就会问这有什么用,有许多理由需要如此去做。
考虑下在传输过程中连接丢失:在这种情况下浏览器和服务器之间的系统可能安全地第二次接收请求,而不破坏其它东西。该过程操作 POST 方法是不可能实现的,因为它只会被触发一次。
-
HEAD
浏览器告诉服务器获取信息,但是只对头信息感兴趣,不需要整个页面的内容。
应用应该处理起来像接收到一个 GET 请求但是不传递实际内容。在 Flask 中你完全不需要处理它,底层的 Werkzeug 库会为你处理的。
-
DELETE
移除给定位置的信息。
-
OPTIONS
给客户端提供一个快速的途径来指出这个 URL 支持哪些 HTTP 方法。从 Flask 0.6 开始,自动实现了该功能。
现在在 HTML4 和 XHTML1 中,表单只能以 GET 和 POST 方法来提交到服务器。
在 JavaScript 和以后的 HTML 标准中也能使用其它的方法。
同时,HTTP 最近变得十分流行,浏览器不再是唯一使用 HTTP 的客户端。比如许多版本控制系统使用 HTTP。
案例
1.请开发一个小应用,URL 地址输入https://xxx/name
(https://xxx
是点击“Web 服务”自动生成的链接,name 表示你输入的名字),访问页面会显示 name。
from flask import Flask, request
app = Flask(__name__)
@app.route('/<username>')
def show_user(username):
return username
2.请完成一个应用,当 URL 是https://xxx/sum/a/b
时,并且为GET请求时, 其中a
和b
都是数字,服务器返回它们的和。
from flask import Flask, request
app = Flask(__name__)
@app.route('/sum/<int:a>/<int:b>', methods=['GET', 'POST'])
def show_user(a, b):
if request.method == 'GET':
return '{0} + {1} = {2}'.format(a, b, a + b)
else:
return 'Please choose GET method to request!'
@app.route('/sum/<int:a>/<int:b>', methods=['GET', 'POST'])
def show_user(a, b):
if request.method == 'GET':
return '{0} + {1} = {2}'.format(a, b, a + b)
else:
return 'Please choose GET method to request!'