flask入门(三)

1.HTTP方法 默认情况下路由只回应GET请求,可通过route()装饰器传递methods参数改变此行为

@app.route('/login',methods=['GET','POST']) def login(): if request.method=='POST': do_the_login() else: show_the_login_form()

HTTP方法 使用场景
GET 获取资源,幂等
HEAD 只关心消息头
POST 创建一个新的资源,提交数据
PUT 完整的替换资源或者创建资源,幂等的
DELETE 删除资源
OPTIONS 获取资源支持所有的HTTP方法
PATCH 局部更新,修改某个已有的资源
2. 响应 视图函数的返回值会自动转换为一个响应对象,转换逻辑如下:
1.返回的是合法的响应对象,从视图直接返回。
2.返回的字符串,响应对象会用字符串数据和默认参数创建。
3.返回的是元组,且元组可以提供额外的信息,这样的元组必须是(response,status,headers)形式,且至少包含一个元素,status覆盖掉状态码,headers可以是列表或字典。
如果都不满足,flask会假设返回值是一个合法的WSGI程序,并转换为请求对象。
可使用make_response()操作上述步骤结果的响应对象,只需将原本需返回的视图放到make_response()内。如:
@app.errorhandler(404) def not_found(error): return render_template('error.html'),404

make_response()可添加其他额外的信息,比如cookie,headers
@app.errorhandler(404) def not_found(error): resp=make_response(render_template('error.html',404)) resp.headers['X-something']='A-value' return resp

3.Cookies 通过请求的cookies属性来访问Cookies,响应对象的set_cookie方法来设置Cookies。
如果需要使用session,不要直接使用Cookies,参考session一节。
响应对象不存在时,需要设置Cookies,使用延时请求回调模块。
请求对象的cookies是客户端提供的所有Cookies的字典。
读取Cookies
from flask import Flask @app.route('/') def index() username=resquest.cookies.get('username')

【flask入门(三)】不用resquest.cookies['username'],以防cookie丢失得到错误值。
设置Cookies
from flask import make_response,render_template @app.route('/') def index() resp=make_response(render_template(...)) resp.set_cookie('username','the-username') return resp

4. session session对象允许在不同请求对象之间储存特定用户的信息。
在Cookies基础上实现,并对Cookies进行密钥签名。除非用户知道密钥,不然只能查看Cookies内容,无法修改。
from flask import Flask,url_for,redirect,session,request,escape app=Flask(__name__)@app.route('/') def index(): if 'username' in session: return 'logged in as %s' %escape(session['username']) return 'You are not logged'@app.route('/login',methods=['GET','POST']) def login(): if request.method=='POST': session['username']=request.form['username'] return redirect(url_for('index')) return ""

escape(s)
将s中的字符(&,<,>,',")转换成HTML。
生成强壮的密钥,一个密钥应该足够随机。
import os secret_key=os.urandom(24)

基于cookie的会话注意:flask会将放进会话对象的值序列至Cookies。
如果你发现某些值在请求之间并没有持久存在,然而确实已经启用了 Cookies,但也没有得到明确的错误信息。这时,请检查你的页面响应中的 Cookies 的大小,并与 Web 浏览器所支持的大小对比。
5.访问请求数据request 导入from flask import request
HTTP方法通过method属性获得。
通过flask.request.form访问POST/PUT提交的数据。
flask.request.args.get()获得URL中的查询参数(?key=value)。

    推荐阅读