url与视图的函数映射
访问book/list的url的时候发现是不可以访问的,因为我们返回额不是字典、元组等等,现在返回的是一个列表。
TypeError: The view function did not return a valid response. The return type must be a string, dict, tuple, Response instance, or WSGI callable, but it was a list.
翻译:该视图没有返回一个可以响应的类型,如字符串、字典、wsgi可调用对象等。
jsonify
通过使用jsonify来进行返回这个json格式的东西。现在就可以将这个列表全部返回了。
传入动态的值进行改变视图
通过定义参数来进行参数。
url与函数映射总结
一个URL要与执行函数进行映射,使用的是@app.route装饰器。@app.route装饰器中,可以指定URL的规则来进行更加详细的映射。
其中,尖括号是固定写法,语法为,variable默认的数据类型是字符串。如果需要指定类型,则要写成converter:variable,其中converter就是类型名称,可以有以下几种:
string: 默认的数据类型,接受没有任何斜杠/的字符串。
int: 整形
float: 浮点型。
path: 和string类似,但是可以传递斜杠/。
uuid: uuid类型的字符串。
any:可以指定多种路径,通过下面一个例子来进行说明:
例子中,item这个函数可以接受两个URL,一个是/article/,另一个是/blog/。并且,一定要传url_path参数,当然这个url_path的名称可以随便。
如果不想定制子路径来传递参数,也可以通过传统的?=的形式来传递参数,例如:/article?id=xxx,这种情况下,可以通过request.args.get(‘id’)来获取id的值。如果是post方法,则可以通过request.form.get(‘id’)来进行获取。
构造url
一般通过一个URL就可以执行到某一个函数。如果反过来,我们知道一个函数,怎么去获得这个URL呢?url_for函数就可以帮我们实现这个功能。url_for()函数接收两个及以上的参数,他接收函数名作为第一个参数,接收对应URL规则的命名参数,如果还出现其他的参数,则会添加到URL的后面作为查询参数。
在公司的开发中,一般是会经常改变url的开发,但是函数名称可能不会改变。
所以需要构造url来进行开发。通过函数名称反转得到url地址。
通过构建URL的方式而选择直接在代码中拼URL的原因有两点:
1、将来如果修改了URL,但没有修改该URL对应的函数名,就不用到处去替换URL了。
2、url_for()函数会转义一些特殊字符和unicode字符串,这些事情url_for会自动的帮我们搞定。如中文、空格、特殊字符等等进行编码转换。
也就是说当14行的url改变了,也不会影响我的url_for进行函数反转。仍然可以进行访问。
指定url末尾的斜杠
有些url的末尾是有斜杠的,但是有些没有,这实际上是两个不同的url。例如:
如果访问第一个,url时就算不带斜杠,也会被重定向到第一个去。但是访问第二个时,如果私自加上了斜杠,会返回一个404错误。
指定http方法
在@app.route()中可以传入关键字methods,来限定访问的方式。
比如说有些定义的是post,但是你去get,会返回method not allowed。
1、如果只需要从服务器上获取数据,一般都是get请求。
2、如果前端需要发送数据给服务器,一般是post请求。
3、在@app.route上添加methods参数,这个参数是一个列表请求,可以传递添加多个。
页面跳转和重定向
重定向分为永久性重定向和暂时性重定向,在页面上体现的操作就是浏览器会从一个页面自动跳转到另外一个页面。比如用户访问了一个需要权限的页面,但是该用户当前并没有登录,因此应该给他重定向到登录页面。
在flask中,重定向是通过flask.redirect(location,code=302)这个函数来实现的,location表示需要重定向到的URL,应该配合之前讲的url_for()函数来使用,code表示采用哪个重定向,默认是302也即暂时性重定向,可以修改成301来实现永久性重定向。