简述
可以通过向规则参数添加可变部分来动态构建 URL。这个可变部分被标记为<variable-name>. 它作为关键字参数传递给与规则关联的函数。
在以下示例中,规则参数为route()装饰器包含<name>附加到 URL 的可变部分‘/hello’. 因此,如果http://localhost:5000/hello/TutorialsPoint被输入为URL在浏览器中,‘TutorialPoint’将提供给hello()函数作为参数。
from flask import Flask
app = Flask(__name__)
@app.route('/hello/<name>')
def hello_name(name):
return 'Hello %s!' % name
if __name__ == '__main__':
app.run(debug = True)
将上述脚本另存为hello.py并从 Python shell 运行它。接下来,打开浏览器并输入网址http://localhost:5000/hello/TutorialsPoint.
以下输出将显示在浏览器中。
除了默认的字符串变量部分之外,还可以使用以下转换器构建规则 -
序号 |
Converters & Description |
1 |
int
接受整数
|
2 |
float
对于浮点值
|
3 |
path
接受用作目录分隔符的斜杠
|
在以下代码中,使用了所有这些构造函数。
from flask import Flask
app = Flask(__name__)
@app.route('/blog/<int:postID>')
def show_blog(postID):
return 'Blog Number %d' % postID
@app.route('/rev/<float:revNo>')
def revision(revNo):
return 'Revision Number %f' % revNo
if __name__ == '__main__':
app.run()
从 Python Shell 运行上述代码。访问网址http://localhost:5000/blog/11在浏览器中。
给定的数字用作参数show_blog()功能。浏览器显示以下输出 -
在浏览器中输入此 URL -http://localhost:5000/rev/1.1
这revision()函数将浮点数作为参数。以下结果出现在浏览器窗口中 -
Flask 的 URL 规则基于Werkzeug’s路由模块。这确保了形成的 URL 是唯一的,并且基于 Apache 制定的先例。
考虑以下脚本中定义的规则 -
from flask import Flask
app = Flask(__name__)
@app.route('/flask')
def hello_flask():
return 'Hello Flask'
@app.route('/python/')
def hello_python():
return 'Hello Python'
if __name__ == '__main__':
app.run()
两条规则看起来相似,但在第二条规则中,尾部斜杠(/)用来。结果,它变成了一个规范的 URL。因此,使用/python要么/python/返回相同的输出。但是,在第一条规则的情况下,/flask/网址导致404 Not Found页。