详解Python中的Cookie模块使用

详解Python中的Cookie模块使用,第1张

概述最近在用GAE开发自己的博客程序。虽然GAE的API没有显式的提供 *** 作Cookie的方法,但他现有的架构,使我们有足够的自由来 *** 作Cookie。

最近在用GAE开发自己的博客程序。虽然GAE的API没有显式的提供 *** 作cookie的方法,但他现有的架构,使我们有足够的自由来 *** 作cookie。

cookie 模块,顾名思义,就是用来 *** 作cookie的模块。cookie这块小蛋糕,玩过Web的人都知道,它是Server与ClIEnt保持会话时用到的信息 切片。 http协议本身是无状态的,也就是说,同一个客户端发送的两次请求,对于Web服务器来说,没有直接的关系。既然这样,有人会问,既然http是无状态 的, 为什么有些网页,只有输入了用户名与密码通过验证之后才可以访问?那是因为:对于通过身份验证的用户,Server会偷偷的在发往ClIEnt的数据中添 加 cookie,cookie中一般保存一个标识该ClIEnt的唯一的ID,ClIEnt在接下来对服务器的请求中,会将该ID以cookie的形式一并 发往Server,Server从回传回来的cookie中提取ID并与相应的用户绑定起来,从而实现身份验证。说白了,cookie就是一个在服务器与客户端之间相互传递的字符串(下图通过firefox的FireBUG插件查看访问Google.com时的cookie)。 越扯越远了,回到我们的主题:Python标准模块 ― cookie。

(上图是http请求头中的cookie信息)

(上图是http响应中的cookie信息)
Cooke模块中定义了4个直接 *** 作cookie的类:Basecookie、Simplecookie、Serialcookie、 Smartcookie。其中,Basecookie是基类,定义了 *** 作cookie的公共部分,其他3个类都继承自Basecookie,它们之间的区 别仅仅在于序列化数据的方式不同。下面简单讲解这些类的使用。

Basecookie基类: Basecookies的行为非常像dict,可以用键/值对的形式来 *** 作它,但是kye必须是字符串,value是Morsel对象 (下面会讲到Morsel)。Basecookies定义了编码/解码,输入/输出 *** 作的公共规范:

Basecookie.value_encode(val):对数据进行序列化/反序列化。这些方法都返回字符串,以便通过http传输。

Basecookie.output():返回字符串,该字符串可以作为http响应头发往客户端。

Basecookie.Js_output():返回嵌入Js脚本的字符串,浏览器通过执行该脚本,就可以得到cooke数据。

Basecookie.load(newdata):解析字符串为cookie数据。

Simplecookie、Serialcookie、Smartcookie都继承自Basecookie,具有一致的行为,它们各自对 Basecookie的value_decode,value_encode进行了重写并实现自己的序列化/反序列化策略,其中:

    Simplecookie内部使用str()来对数据进行序列化;     Serialcookie则通过pickle模块来序列化反序列化数据;     Smartcookie相对聪明点,对于非字符串数据,使用pickle序列/反序列化,否则将字符串原样返回。

下面的例子简单的说明如何使用cookie模块:
 

import cookie c = cookie.Simplecookie()c['name'] = 'DarkBull'c['address'] = 'ChinaHangZhou'c['address']['path'] = '/' # 路径c['address']['domain'] = 'appspot.com' # domainc['address']['expires'] = 'Fir,01-Oct-2010 20:00:00 GMT'  # 过期时间print c.output()print c.Js_output() # 输出结果,与上图对照# Set-cookie: address=ChinaHangZhou; Domain=appspot.com; expires=Fir,01-Oct-2010 20:00:00 GMT; Path=/# Set-cookie: name=DarkBull # 作为脚本输出# <script type="text/JavaScript"># document.cookie = "address=ChinaHangZhou; Domain=appspot.com; expires=Fir,01-Oct-2010 20:00:00 GMT; Path=/";# </script> # <script type="text/JavaScript"># document.cookie = "name=DarkBull";# </script>

Morsel类 : 用于表示cookie中每一项数据的属性而抽象的类。这些属性包括:expires,path,comment,domain,max-age,secure,version等等(看上图下划线标注部分)。如果你玩过web,对这些应该不会陌生,可以在RCF2109中找到他们的具体定义

Morsel.key,Morsel.value:cookie数据项的key/value(value可以是二进制数据);

Morsel.coded_value:数据编码后得到的字符串。http协议是基于文本的协议,Server无法直接向ClIEnt发送二进制数据,只有序列化成字符串后,才能发往ClIEnt;

Morsel.set(key,value,coded_value):设置cookie数据项的key、value、coded_value;

Morsel.isReversvedKey(key):如果key是expires,version,httponly中的一个,返回True,否则返回False;

Morsel.output():返回型如“Set-cookie: …”的字符串,表示一个cookie数据项;

Morsel.Js_output():返回cookie数据项的脚本字符串;

Morsel.OutputString(): 返回Morsel的字符串表示;

Morsel使用示例:
 

import cookie m = cookie.Morsel()m.set('name','DarkBull','DarkBull')m['expires'] = 'Fir,01-Oct-2010 20:00:00 GMT'm['domain'] = 'appspot.com'print m.output() # 结果# Set-cookie: name=DarkBull; Domain=appspot.com; expires=Fir,01-Oct-2010 20:00:00

总结

以上是内存溢出为你收集整理的详解Python中的Cookie模块使用全部内容,希望文章能够帮你解决详解Python中的Cookie模块使用所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1206107.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存