Flask框架URL管理操作示例【基于@app.route】
本文实例讲述了Flask框架URL管理操作。分享给大家供大家参考,具体如下:
动态URL规则
URL规则可以添加变量部分,也就是将符合同种规则的URL抽象成一个URL模式,如“/item/1/”,“/item2/”,假如不抽象,我们就得这样写:
@app.route("/item/1/")
动态URL写法:
@app.route("/item1/<id>/") def item1(id): pass
尖括号的内容是动态的,凡是匹配到的/item/前缀的URL都会被映射到这个路由上,在内部把id作为参数而获得。它使用了特殊的字段标记,默认类型是字符串。如果需要制定参数类型需要标记成这样的格式,converter有下面几种:
- string:接收任何没有斜杠”/”的文本(默认)
- int:接收整数
- float:同int,但是接收浮点数
- path:和默认的相似,但也接收斜杠
- uuid:只接受uuid字符串
- any:可以指定多种路径,但是需要传入参数
@app.route("/any(a,b):page_info") def page_info(page_info): pass
访问/a/和访问/b/都符合这个规则,如果不希望定制子路径,还可以通过传递参数的方式,例如:/item1?name=laowang。默认使用的是GET
方法才能请求,开发者可以通过request.args.get("name")
。如果需设定使用POST
请求,在URL后面,添加methods=["POST"]
,如app.route("/item1",methods=["POST"])
,开发者可以使用 request.form.get('name')
获得传入的name的值。
唯一URL
Flask的URL规则基于Werkzeug的路由模块。这个模块背后的思想是基于Apache以及更早的HTTP服务器的主张,希望保证优雅且唯一的URL。
举个栗子:
@app.route("/about/") def about(): ...
上述栗子像一个文件系统中的文件夹,访问一个结尾不带斜线的URL会被重定向到带斜线的规范的URL上去,这样也有助于避免搜索引擎引同一个页面两次.
再举个栗子:
@app.route("/about") def about(): ...
URL不带斜线,当用户访问带斜线的URL”/about/”会产生一个Not Found的错误。
希望本文所述对大家基于Flask框架的Python程序设计有所帮助。