cookie是运用客户端存储交互状态的一种方式,而session则主要是在服务器端存储交互状态的一种方式
flask中的session是以密钥签名加密的cookie,即用户可以查看你的cookie
获取cookie可以使用:
flask.request.cookies.get('name')
设置cookie则需要使用make_response对象:
resp=make_response(content)#content返回页面内容
resp.set_cookie('username','the username')#设置名为username的cookie
演示使用cookie跟踪用户的实例
#-*-encoding:utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf8')
import flask
html_txt='''#定义设置cookie页面内容
<!DOCTYPE html>
<html>
<body>
<h2>收到GET请求<h2/>
<a href='/get_info'>获取cookie信息</a>
</body>
</html>
'''
app=flask.Flask(__name__)
@app.route('/set_info/<name>')#从URL中获取参数URL装饰器
def set_cks(name):
name=name if name else 'anonymous'
resp=flask.make_response(html_txt)#构造响应对象
resp.set_cookie('name',name)#设置名为name的cookie
return resp
@app.route('/get_info')
def get_cks():
name=flask.request.cookies.get('name')#获取cookie信息
return '获取的cookie信息是:'+name#返回带cookie信息的页面内容
if __name__=='__main__':
app.run(debug=True)
演示使用session跟踪用户的实例
#-*-encoding:utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf8')
import flask
html_txt='''
<!DOCTYPE html>
<html>
<body>
<h2>收到GET请求<h2/>
<a href='/get_info'>获取cookie信息</a>
</body>
</html>
'''
app=flask.Flask(__name__)
@app.route('/set_info/<name>')
def set_cks(name):
name=name if name else 'anonymous'
flask.session['name']=name#设置session
return html_txt
@app.route('/get_info')
def get_cks():
name='name' in flask.session and flask.session['name']
if name:
return '获取的会话信息是:'+name
else:
return '没有会话信息'
if __name__=='__main__':
app.secret_key='dfadff#$#5dgfddgssgfgsfgr4$T^%^'#设置cookie密钥
app.run(debug=True)