客官您最终回头了!

让我们本着探(zuo)索(si)精神把 session.py 看完吧...

首先看看须要的库:

pickle 一个用于序列化反序列化的库(听不懂?你直接看成和 json 一样作用即可了...)

hmac 和 hashlib 用于生成加密字符串

uuid 用于生成一个唯一 id

memcache  Python 的 memcache client

这里面有三个类。SessionData Session 和 SessionManager。

先看最简单的 SessionData。

SessionData 用于以字典的结构存储 session 数据,继承于字典。事实上仅仅比字典多了两个成员变量:

# 继承字典,由于 session 的存取相似于字典
class SessionData(dict):
# 初始化时提供 session id 和 hmac_key
def __init__(self, session_id, hmac_key):
self.session_id = session_id
self.hmac_key = hmac_key

然后就是真正的 Session 类了。Session 类继承于 SessionData, 注意,它还是十分像内置类型字典。仅仅是重写了自己的初始化方法,并定义了 save 接口——用于保存改动后的 session 数据。

# 继承 SessionData 类
class Session(SessionData):
# 初始化。绑定 session_manager 和 tornado 的相应 handler
def __init__(self, session_manager, request_handler):
self.session_manager = session_manager
self.request_handler = request_handler try:
# 正常是获取该 session 的全部数据,以 SessionData 的形式保存
current_session = session_manager.get(request_handler)
except InvalidSessionException:
# 假设是第一次訪问会抛出异常,异常的时候是获取了一个空的 SessionData 对象,里面没有数据。但包括新生成的
# session_id 和 hmac_key
current_session = session_manager.get() # 取出 current_session 中的数据,以键值对的形式迭代存下
for key, data in current_session.iteritems():
self[key] = data # 保存下 session_id
self.session_id = current_session.session_id
# 以及相应的 hmac_key
self.hmac_key = current_session.hmac_key # 定义 save 方法,用于 session 改动后的保存,实际调用 session_manager 的 set 方法
def save(self):
self.session_manager.set(self.request_handler, self)

__init__ 方法比較难理解。基本流程是定义自己的 session_manager 和 handler 处理对象。

然后通过 session_manager 获得已有的 session 数据。用这些数据初始化一个訪问的用户的 session, 假设用户是第一次訪问,那么他拿到的是一个新的 SessionData 对象。由于有可能是新用户,所以这里要对 session_id 和 hmac_key(什么鬼) 进行赋值。

而 save 方法是提供了对改动 session 数据后的保存接口,实际是调用 session_manager 的 set 方法。详细实现先不考虑。

看到这两个类,你就应该对 session 的工作有基本理解,能够从用户訪问的流程来考虑。

注意 BaseHandler 这个入口,每一个用户的訪问都是一次 HTTP 请求。

当用户第一次訪问或者上一次的 session 过期了。这时用户訪问时 tornado 建立了一个 handler 对象(该 handler 一定继承于 BaseHandler),而且在初始化时建立了一个 session 对象,由于是新訪问。所以眼下 session 里面没有数据。在之后採用 键/值 对的形式读写 session(不要忘了
Session 具有字典的全部操作),改动后通过 save 方法保存 session。假设用户不是新訪问,那么也是依照上述的流程,只是 session 初始化时把 之前的数据取出来保存在该实例中。当用户结束訪问,HTTP 断开连接。handler 实例销毁,session 实例销毁(注意,是实例销毁,不是数据销毁)。

是不是感觉有点晕....嗯 我也晕了....理解完我们再看 SessionManager. 这个类大一点...喂...童鞋别走啊!

真的仅仅剩一点了....喂....

【源代码剖析】tornado-memcached-sessions —— Tornado session 支持的实现(二)的更多相关文章

  1. tornado 09 cookie和session

    tornado 09 cookie和session 一.cookie #有什么办法能够让浏览器记住登录信息,下次再打开的时候可以自动登录?网站是如何记录登录信息的? class SetCookieHa ...

  2. web框架--tornado之cookie与session初识

    cookie的本质其实就是在浏览器端保存的键值对, 每当浏览器端发送一次请求, 都会将这些键值对附加在请求中并发送给服务器端. 一.目录结构 二.main_pro.py #!/usr/bin/env ...

  3. 【转】nginx+tomcat+memcached (msm)实现 session同步复制

    出现session不同步时,请放到content.xml中,实际验证有效: tomcat + memcached + nginx 实现session共享 这里重点强调如何实现linux服务器上 服务器 ...

  4. memcached完全剖析–1. memcached的基础

    系列文章导航: memcached完全剖析–1. memcached的基础 memcached全面剖析–2. 理解memcached的内存存储 memcached全面剖析–3. memcached的删 ...

  5. 豌豆夹Redis解决方式Codis源代码剖析:Proxy代理

    豌豆夹Redis解决方式Codis源代码剖析:Proxy代理 1.预备知识 1.1 Codis Codis就不详细说了,摘抄一下GitHub上的一些项目描写叙述: Codis is a proxy b ...

  6. [转载]memcached完全剖析--1. memcached的基础

    转载自:http://charlee.li/memcached-001.html 翻译一篇技术评论社的文章,是讲memcached的连载.fcicq同学说这个东西很有用,希望大家喜欢. 发表日:200 ...

  7. 转】从源代码剖析Mahout推荐引擎

    原博文出自于: http://blog.fens.me/mahout-recommend-engine/ 感谢! 从源代码剖析Mahout推荐引擎 Hadoop家族系列文章,主要介绍Hadoop家族产 ...

  8. 菜鸟nginx源代码剖析数据结构篇(一)动态数组ngx_array_t

    菜鸟nginx源代码剖析数据结构篇(一)动态数组ngx_array_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csd ...

  9. 菜鸟nginx源代码剖析数据结构篇(八) 缓冲区链表ngx_chain_t

    菜鸟nginx源代码剖析数据结构篇(八) 缓冲区链表 ngx_chain_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog. ...

  10. 【Java集合源代码剖析】ArrayList源代码剖析

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/35568011 转载请注明出处:http:// ...

随机推荐

  1. 百度AI车牌识别测试

    测试背景 百度已发布诸多AI应用,其中包含车牌识别,免费使用量是200次/日.付费的话,按月调用次数在20万次到50万次之间,每日10000次,月费用为0.0035*300000=1050元. 详见: ...

  2. taskctl命令行类(sh、exe、python新增scp)插件升级扩展

    转载自: http://www.taskctl.com/forum/detail_129.html 上次写了一个帖子 TASKCTL中不使用代理,通过ssh免密连接执行远程脚本配置(SSH插件扩展)h ...

  3. 预测学习、深度生成式模型、DcGAN、应用案例、相关paper

    我对GAN"生成对抗网络"(Generative Adversarial Networks)的看法: 前几天在公开课听了新加坡国立大学[机器学习与视觉实验室]负责人冯佳时博士在[硬 ...

  4. HDU_1874_畅通工程续_最短路问题

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  5. CentOS下安装微软雅黑字体

    CentOS下安装微软雅黑字体   微软雅黑下载地址:http://download.csdn.net/detail/u012547633/9796219 1.先从你本机 C:\Windows\Fon ...

  6. linux下C/C++程序的内存布局

    内核空间和用户空间: 我们在编写程序时使用的内存空间叫虚拟内存,程序在运行时,要完成虚拟内存到物理内存的转换.假如在32位环境上,理论上我们可以使用的虚拟内存空间是4GB,但实际上这4GB并不能完全给 ...

  7. Word 格式优化

    Word 格式优化. Word 支持 VBA 意味着,可以编程实现自己想要的格式拓展. Word 代码布局

  8. [Algorithm] 7. Serialize and Deserialize Binary Tree

    Description Design an algorithm and write code to serialize and deserialize a binary tree. Writing t ...

  9. Gym - 101670H Go Northwest!(CTU Open Contest 2017 思维题+map)

    题目: Go Northwest! is a game usually played in the park main hall when occasional rainy weather disco ...

  10. db2 in out inout

    总结: in  给存储过程传的参数,传一个确定的值 out  传的时候传一个非确定的变量v或者“?”  .在存储过程里面计算一个结果赋给v,这个变量v在存储过程执行完之后就是一个确定的值了. inou ...