python学习笔记(3)---cookie & session
一、cookie & session
1、cookie:
cookie 就是由服务器发送给客户端的特殊信息,而这些信息以文本的方式存放在客户端,然后客户端每次向服务器发送请求都会带上这些特殊信息。让服务器来识别你的计算机。例如:你访问某些网站的时候,一些网站登录界面问是否保存密码,如果你选择保存后再登录,那么下次访问网站的时候就不许重复登录动作了,这就是Cookie实现的。
cookie缺点:
① cookie数量和长度限制,每个domain最多只能有20条cookie,并且每个cookie长度不能超过4k
② 安全性问题,如果cookie被人拦截,那个人就能拿到session信息
③ 有些状态无法保存在客户端
虽然cookie有这些缺点,但是cookie能够很好的做身份识别。
2、session:
session称为“会话控制”,session对象存储特定用户会话所需的属性及配置信息。当用户在Web页跳转时,存储在session对象中的变量不会丢失。
session和cookie区别:
① cookie数据存储在客户的浏览器上,session数据放在服务器上
② cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺骗,考虑到安全应当使用session
③ session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能,考虑到减轻服务器性能方面,应当使用cookie
④ 单个cookie保存的数据不能超过4k,很多浏览器都限制一个站点最多保存20个cookie
⑤ 登录信息等重要信息存放为session,某些需要保留的信息放在cookie
二、手动使用cookie登录
比较傻的方法:直接复制cookie,手动放入请求头
from urllib import request
if __name__ =="__main__":
# 模拟登录人人个人主页
url = "http://www.renren.com/967981984/profile"
headers={
"cookie":"anonymid=jlxrqipq-yd1b41; depovince=BJ; _r01_=1; JSESSIONID=abcrdbDitjgodcWbI_kxw; ick_login=666ef91c-38c0-4863-b69f-bd9b48f23b6a; t=ab090cc8a1b9e5a93991f467cf8f3eab4; societyguester=ab090cc8a1b9e5a93991f467cf8f3eab4; id=967981984; xnsid=3505b17e; jebecookies=e7f4d1cc-1fd5-4e3d-82e2-57fc6f652835|||||; ver=7.0; loginfrom=null; wp_fold=0; jebe_key=7da3f557-b4af-410d-b7c8-07ef5c61cd3a%7C873bc0529825e88a727db5146c0adb40%7C1536708771061%7C1"
}
req = request.Request(url, headers = headers)
res = request.urlopen(req)
html = res.read().decode()
# 把页面保存到本地
with open("res.html", "w") as f:
f.write(html)
三、使用cookie自动登录
http模块中有一些cookie模块,通过他们我们可以自动使用cookie
1、CookieJar
- 管理存储cookie,向传出的http请求添加cookie
- cookie存储在内存中,CookJar实例回收后cookie将消失
2、FileCookieJar(filename, delayload = None, policy = None)
- 使用文件管理cookie
- filename是保存的文件的名字
3、MozillaCookieJar(filename, delayload = None, policy = None)
- 创建与mocilla(火狐)浏览器cookie.txt兼容的FileCookieJar
4、LwpCookieJar(filename, delayload = None, policy = None)
- 创建与LwpCookieJar标准兼容的Set-Cookie3格式的FileCookieJar
关系 CookieJar -> FileCookieJar -> MozillaCookieJar -> LwpCookieJar
利用cookieJar访问人人
代码实现流程:
1、打开登录页面自动通过账号和密码
2、自动提取反馈回来的cookie
3、利用提取的cookie登录隐私页面
from urllib import request,parse
from http import cookiejar
# 创建cookiejar实例
cookie = cookiejar.Cookiejar()
# 生成cookiejar管理器
cookie_handler = request.HTTPCookieProcessor(cookie)
# 创建http管理器
http_handler = request.HTTPHandler()
# 创建https管理器
https_handler = request.HTTPSHandler()
# 创建请求管理器
opener = request.build_opener(http_handler, https_handler, cookie_handler) # 登录函数
def login():
'''
负责初次登录
需要输入用户名、密码来获取登录cookie的凭证
'''
# 通过抓包获取的登录页面
url = "http://www.renren.com/PLogin.do"
# email 是登录账号 password是登录密码
data = {
"email":"",
"password":""
}
data = parse.urlencode(data)
req = request.Request(url, data = data.encode())
rsq = opener.open(req)
def getHomePage():
url = "http://www.renren.com/967981984/profile"
# 如果已经执行了Login函数,则opener自动包含相应的cookie值
rsp = opener.open(url)
html = rsp.read().decode()
with open("rsp.html", "w") as f:
f.write(html)
if __name__ =='__main__':
login()
getHomePage()
四、cookie属性
使用代码查看cookie属性
from urllib import request,parse
from http import cookiejar
cookie = cookiejar.CookieJar()
cookie_handler = request.HTTPCookieProcessor(cookie)
http_handler = request.HTTPHandler()
https_handler = request.HTTPSHandler()
opener = request.build_opener(http_handler, https_handler, cookie_handler) def login():
url = "http://www.renren.com/PLogin.do"
data = {
"email":""
"password":""
}
data = parse.urlencode(data)
req = request.Request(url, data= data.encode())
rsp = opner.open(req) if __name__ == "__main__":
login()
print(cookie)
for item in cookie:
print(item)
执行结果:

cookie属性
- name:名称
- value:值
- domain:可以访问此cookie域名
- path:可以访问cookie的页面路径
- expire:过期时间
- size:大小
- http:字段
四、文件保存FileCookieJar
from urllib import request, parse
from http import cookiejar
#创建cookie文件
filename = "cookie.txt"
# 创建MOzillacookiejar实例
cookie = cookiejar.MozillaCookieJar(filename)
# 生成cookiejar管理器
cookie_handler = request.HTTPCookieProcessor(cookie)
# http管理器
http_handler = request.HTTPHandler()
# https管理器
https_handler = request.HTTPSHandler()
# opener管理器
opener = request.bulid_opener(http_handler, https_landler, cookie_handler) def login():
url = "http://www.renren.com/PLogin.do"
data = {
"email": "",
"password": ""
}
data = parse.urlencode(data)
req = request.Request(url, data = data.encode())
res = opener.open(req)
cookie.save(ignore_discard=True, ignore_expires=True)
if __name__ =='__main__':
login()
第27行可以直接cookie.save()不带参数
ignore_discard=True :将要丢弃cookie的也保存
ignore_expires=True : 如果文件中的cookie已过期,继续保存
python学习笔记(3)---cookie & session的更多相关文章
- Python Web学习笔记之Cookie,Session,Token区别
一.Cookie,Session,Token简介 # 这三者都解决了HTTP协议无状态的问题 session ID or session token is a piece of data that i ...
- node学习笔记9——cookie,session相关操作
下面讲的都是基Express及相关的包.所以在实践本篇文章之前,通过npm安装好Express, cookie-parser, cookie-session这三个安装包. 先简单说一下,如何用Expr ...
- Javaweb学习笔记5—Cookie&Session
今天来讲javaweb的第五阶段学习. Cookie和Session同样是web开发常用到的地方. 老规矩,首先先用一张思维导图来展现今天的博客内容. ps:我的思维是用的xMind画的,如果你对我的 ...
- python学习笔记目录
人生苦短,我学python学习笔记目录: week1 python入门week2 python基础week3 python进阶week4 python模块week5 python高阶week6 数据结 ...
- openresty 学习笔记六:使用session库
openresty 学习笔记六:使用session库 lua-resty-session 是一个面向 OpenResty 的安全和灵活的 session 库,它实现了 Secure Cookie Pr ...
- python学习笔记整理——字典
python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...
- VS2013中Python学习笔记[Django Web的第一个网页]
前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...
- python学习笔记之module && package
个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...
- python学习笔记(六)文件夹遍历,异常处理
python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...
- python学习笔记--Django入门四 管理站点--二
接上一节 python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Autho ...
随机推荐
- 我要为运维说一句,我们不是网管,好不!!Are you know?
运维 运维,这里指互联网运维,通常属于技术部门,与研发.测试.系统管理同为互联网产品技术支撑的4大部门,这个划分在国内和国外以及大小公司间都会多少有一些不同. 一个互联网产品的生成一般经历的过程是:产 ...
- 使用 Azure CLI 将 IaaS 资源从经典部署模型迁移到 Azure Resource Manager 部署模型
以下步骤演示如何使用 Azure 命令行接口 (CLI) 命令将基础结构即服务 (IaaS) 资源从经典部署模型迁移到 Azure Resource Manager 部署模型. 本文中的操作需要 Az ...
- SSIS ->> 管理和维护SSISDB
Comming soon!!! 参考文献: Setup and Performance Issues with the Integration Services (SSIS) 2012 Catalog ...
- 爬虫入门之Scrapy框架基础rule与LinkExtractors(十一)
1 parse()方法的工作机制: 1. 因为使用的yield,而不是return.parse函数将会被当做一个生成器使用.scrapy会逐一获取parse方法中生成的结果,并判断该结果是一个什么样的 ...
- Ubuntu中的两种link的区别
Ubuntu中有两种link(windows世界中文件的“快捷方式”),一个是hard link(硬链接),另一个是symbolic link(软链接). 那么,什么是硬链接,什么又是软链接呢? 硬链 ...
- 在Java中字符串是通过引用传递的?
这是一个经典的java问题.在stackoverflow上,许多类似的问题已经被问过了,但是许多回答是错误的或不完整的. 如果你不想深入思考的话,这个问题很简单.如果你想明白的更彻底,那么问题可能容易 ...
- 如何将程序添加到Windows桌面右键菜单
在Windows桌面上右键单击鼠标时,将显示默认菜单.如果您想要将其它程序添加到Windows桌面右键菜单中,则可以按照以下步骤执行: 运行WinUtilities上下文菜单管理器 点击添加 选择菜单 ...
- GitHub & Git 基础 (YouTube中文翻译版)
GitHub & Git 基础系列视频 播放列表 由于视频资源在YouTube上,可能需要FQ:https://code.google.com/p/chromeplus/ 视频包括以下内容 1 ...
- (转)C++ 自由存储区是否等价于堆?
“free store” VS “heap” 当我问你C++的内存布局时,你大概会回答: “在C++中,内存区分为5个区,分别是堆.栈.自由存储区.全局/静态存储区.常量存储区”. 如果我接着问你 ...
- 关于项目中的DAL数据接入层架构设计
摘要:项目中对关系型数据库的接入再寻常不过,也有海量的ORM工具可供选择,一个一般性的DAL数据接入层的结构却大同小异,这里就分享一下使用Hibernate.Spring.Hessian这三大工具对D ...