久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

Python中的Cookie模塊如何使用

瀏覽:107日期:2022-07-22 17:56:51

Cookie 模塊,顧名思義,就是用來操作Cookie的模塊。

Cookie這塊小蛋糕,玩過Web的人都知道,它是Server與Client保持會話時用到的信息 切片。 Http協(xié)議本身是無狀態(tài)的,也就是說,同一個客戶端發(fā)送的兩次請求,對于Web服務(wù)器來說,沒有直接的關(guān)系。既然這樣,有人會問,既然Http是無狀態(tài) 的, 為什么有些網(wǎng)頁,只有輸入了用戶名與密碼通過驗證之后才可以訪問?

那是因為:對于通過身份驗證的用戶,Server會偷偷的在發(fā)往Client的數(shù)據(jù)中添 加 Cookie,Cookie中一般保存一個標(biāo)識該Client的唯一的ID,Client在接下來對服務(wù)器的請求中,會將該ID以Cookie的形式一并 發(fā)往Server,Server從回傳回來的Cookie中提取ID并與相應(yīng)的用戶綁定起來,從而實現(xiàn)身份驗證。說白了,Cookie就是一個在服務(wù)器與客戶端之間相互傳遞的字符串(下圖通過FireFox的FireBug插件查看訪問google.com時的Cookie)。

Cooke模塊中定義了4個直接操作Cookie的類:BaseCookie、SimpleCookie、SerialCookie、 SmartCookie。其中,BaseCookie是基類,定義了操作Cookie的公共部分,其他3個類都繼承自BaseCookie,它們之間的區(qū) 別僅僅在于序列化數(shù)據(jù)的方式不同。下面簡單講解這些類的使用。

BaseCookie基類: BaseCookies的行為非常像dict,可以用鍵/值對的形式來操作它,但是kye必須是字符串,value是Morsel對象 (下面會講到Morsel)。BaseCookies定義了編碼/解碼,輸入/輸出操作的公共規(guī)范:

BaseCookie.value_encode(val):對數(shù)據(jù)進行序列化/反序列化。這些方法都返回字符串,以便通過Http傳輸。 BaseCookie.output():返回字符串,該字符串可以作為Http響應(yīng)頭發(fā)往客戶端。 BaseCookie.js_output():返回嵌入js腳本的字符串,瀏覽器通過執(zhí)行該腳本,就可以得到cooke數(shù)據(jù)。 BaseCookie.load(newdata):解析字符串為Cookie數(shù)據(jù)。

SimpleCookie、SerialCookie、SmartCookie都繼承自BaseCookie,具有一致的行為,它們各自對 BaseCookie的value_decode, value_encode進行了重寫并實現(xiàn)自己的序列化/反序列化策略,其中:

SimpleCookie內(nèi)部使用str()來對數(shù)據(jù)進行序列化;

SerialCookie則通過pickle模塊來序列化反序列化數(shù)據(jù);

SmartCookie相對聰明點,對于非字符串?dāng)?shù)據(jù),使用pickle序列/反序列化,否則將字符串原樣返回。

下面的例子簡單的說明如何使用Cookie模塊:

import Cookiec = 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()# 輸出結(jié)果,與上圖對照# 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中每一項數(shù)據(jù)的屬性而抽象的類。這些屬性包括:expires, path, comment, domain, max-age, secure, version等等(看上圖下劃線標(biāo)注部分)。如果你玩過web,對這些應(yīng)該不會陌生,可以在RCF2109中找到他們的具體定義

Morsel.key,Morsel.value:Cookie數(shù)據(jù)項的key/value(value可以是二進制數(shù)據(jù));

Morsel.coded_value:數(shù)據(jù)編碼后得到的字符串。Http協(xié)議是基于文本的協(xié)議,Server無法直接向Client發(fā)送二進制數(shù)據(jù),只有序列化成字符串后,才能發(fā)往Client;

Morsel.set(key, value, coded_value):設(shè)置Cookie數(shù)據(jù)項的key、value、coded_value;

Morsel.isReversvedKey(key):如果key是expires, path, comment, domain, max-age, secure, version, httponly中的一個,返回True,否則返回False;

Morsel.output():返回型如“Set-Cookie: …”的字符串,表示一個Cookie數(shù)據(jù)項;

Morsel.js_output():返回Cookie數(shù)據(jù)項的腳本字符串;

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

Morsel使用示例:

import Cookiem = Cookie.Morsel()m.set(’name’, ’DarkBull’, ’DarkBull’)m[’expires’] = ’Fir, 01-Oct-2010 20:00:00 GMT’m[’domain’] = ’appspot.com’print m.output()# 結(jié)果# Set-Cookie: name=DarkBull; Domain=appspot.com; expires=Fir, 01-Oct-2010 20:00:00

知識點擴展:

為什么要使用Cookie呢?

Cookie,指某些網(wǎng)站為了辨別用戶身份、進行session跟蹤而儲存在用戶本地終端上的數(shù)據(jù)(通常經(jīng)過加密)

比如說有些網(wǎng)站需要登錄后才能訪問某個頁面,在登錄之前,你想抓取某個頁面內(nèi)容是不允許的。那么我們可以利用Urllib2庫保存我們登錄的Cookie,然后再抓取其他頁面就達到目的了。

以上就是Python中的Cookie模塊如何使用的詳細內(nèi)容,更多關(guān)于Python中的Cookie模塊用法的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 日韩精品免费在线视频 | 99pao成人国产永久免费视频 | 免费激情网站 | 久久久99国产精品免费 | 午夜社区| 国产欧美综合一区二区三区 | 亚洲精品v日韩精品 | 久久伊人免费视频 | aⅴ色国产 欧美 | 青青草一区 | 99精品福利视频 | 国产在线小视频 | 日韩激情综合网 | 国产日韩一区二区三区 | 国产精品福利午夜在线观看 | 性视频黄色 | 艳妇荡乳豪妇荡淫 | 久久久久久九九 | 成人av免费观看 | 91 久久| 91免费看片| 日韩久久一区二区 | 人人干天天干 | 在线亚洲人成电影网站色www | 亚洲成人精品一区 | 日韩欧美国产精品综合嫩v 亚洲欧美日韩在线 | 国产美女啪啪 | a级片在线观看 | 日韩亚洲精品在线观看 | 欧美日韩视频一区二区 | 国产成人精品久久二区二区 | 亚洲免费视频在线 | 国产一区二区三区在线视频 | 精品国产欧美 | 亚洲激情在线观看 | 91社区在线观看 | 男女国产视频 | 精品久久久一区二区 | 色婷婷综合在线视频 | 精品国产一区二区三区成人影院 | 久久久www成人免费无遮挡大片 |