文章目录
Cookie
设置cookie
RequestHandler提供了操作cookie的方法
set_cookie(name, value, domain=None, expires=None, path='/', expires_days=None)
| 参数名 | 说明 |
|---|---|
| name | cookie名 |
| value | cookie值 |
| domain | 提交cookie时匹配的域名 |
| path | 提交cookie时匹配的路径 |
| expires | cookie的有效期,可以是时间戳整数、时间元组或者datetime类型,为UTC时间 |
| expires_days | cookie的有效期,天数,优先级低于expires |
import tornado.web
import tornado.ioloop
import time
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.set_cookie("cookie1", "version1")
self.set_cookie("cookie2", "version2", path="/cookie2",
expires=time.strptime("2019-08-11 23:59:59", "%Y-%m-%d %H:%M:%S"))
self.set_cookie("cookie3", "version3", expires_days=20)
# 利用time.mktime将本地时间转换为UTC标准时间
self.set_cookie("cookie4", "version4",
expires=time.mktime(time.strptime("2019-08-11 23:59:59", "%Y-%m-%d %H:%M:%S")))
self.write("OK")
if __name__ == '__main__':
app = tornado.web.Application([
(r'/', MainHandler), # 生成服务实例,通常包含路由信息
], debug=True)
app.listen(8000) # 监听端口
tornado.ioloop.IOLoop.current().start() # 开启服务


通过set_header设置cookie
设置cookie实际是通过设置header的Set-Cookie来实现
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.set_cookie("cookie1", "version1")
self.set_cookie("cookie2", "version2", path="/cookie2",
expires=time.strptime("2019-08-11 23:59:59", "%Y-%m-%d %H:%M:%S"))
self.set_cookie("cookie3", "version3", expires_days=20)
# 利用time.mktime将本地时间转换为UTC标准时间
self.set_cookie("cookie4", "version4",
expires=time.mktime(time.strptime("2019-08-11 23:59:59", "%Y-%m-%d %H:%M:%S")))
# 通过set_header来设置cookie
self.set_header("Set-Cookie", "cookie5=version5; expires=Fri, 11 Aug 2019 15:59:59 GMT; Path=/")
self.write("OK")
获取cookie
get_cookie(name, default=None)
import tornado.web
import tornado.ioloop
import tornado.httpserver
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.set_cookie("cookie1", "version1") # 设置cookie
cookie = self.get_cookie("cookie1") # 获取cookie
self.write(cookie) # 将cookie打印出来
if __name__ == '__main__':
app = tornado.web

本文详细介绍了Tornado框架中如何操作Cookie,包括设置、获取和清除。接着讨论了安全Cookie的实现,包括签名和秘钥的生成。此外,还深入探讨了Tornado的XSRF保护机制,解释了同源策略和如何通过模板或非模板方式实现XSRF保护。文章强调了避免在Cookie中存储敏感数据的重要性。
最低0.47元/天 解锁文章
165

被折叠的 条评论
为什么被折叠?



