python爬虫之cookies

本文详细解释了Cookies在Web领域的功能,如何在登录过程中保存账号密码,并介绍了如何通过抓包软件Fiddler获取Cookies。进一步,文章演示了如何在Python中使用requests库的cookies函数和urllib2库的HTTPCookieProcessor来利用获取的Cookies进行网页请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

cookies在web领域里面是一个很神奇的东西,它可以理解为你的密匙,
比如在新浪微博中你登录只有,会有记住密码这一个选项。当下次登录的时候,就不用输入对应的账号密码了,这是为啥?
这就是cookies的用处,它可以记住你的账号密码,不过记住的不是明文的账号密码,它是一段加密之后的数据段,

我们怎么获取cookies呢?
答案:抓包
每次我们点击登录按钮的时候,网站会提交一份包含账号密码,Host,Referer,User-Agent,等的一些信息,同时,生成一份cookies,通过抓包软件抓取发送的这条信息之后,我们就得到了直接连接sina.cn的钥匙。下次登入的时候,就直接把cookies发送过去就好了,
我这里使用的抓包软件是Fiddler,挺简洁的,

那么,我们抓到cookies之后怎么使用呢?
我们在前面介绍过两个库,requests个urllib2.HTTPCookieProcessor
requests有一个cookies函数,这个函数的具体功能可以在python shell里面输入如下查看他的信息

dir(requests.cookies)

填写这个变量之后,再get一次,就可以得到想要的html数据了。
至于cookies有时候是变动的这一条,你们可以自己去摸索,我在网上学习的sina.cn变动很简单,你们可以从这个下手

还有一个方法urllib2.HTTPCookieProcessor

opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))
urllib2.install_opener(opener)

这样添加进去了,只有只需要添加必要的header就可以直接urlopen了,

# JD_AutoBuy ## 京东抢购 Python爬虫,自动登录京东网站,查询商品库存,价格,显示购物车详情等。 可以指定抢购商品,自动购买下单,然后手动去京东付款就行。 ## chang log + 2017-03-30 实现二维码扫码登陆 ## 运行环境 Python 2.7 ## 第三方库 - [Requests][1]: 简单好用,功能强大的Http请求库 - [beautifulsoup4][2]: HTML文档格式化及便签选择器 ## 环境配置 ``` Python pip install requests pip install beautifulsoup4 ``` ## 使用帮助 ``` cmd > python scraper-jd.py -h usage: scraper-jd.py [-h] [-u USERNAME] [-p PASSWORD] [-g GOOD] [-c COUNT] [-w WAIT] [-f] [-s] Simulate to login Jing Dong, and buy sepecified good optional arguments: -h, --help show this help message and exit -u USERNAME, --username USERNAME Jing Dong login user name -p PASSWORD, --password PASSWORD Jing Dong login user password -g GOOD, --good GOOD Jing Dong good ID -c COUNT, --count COUNT The count to buy -w WAIT, --wait WAIT Flush time interval, unit MS -f, --flush Continue flash if good out of stock -s, --submit Submit the order to Jing Dong ``` ## 实例输出 ``` cmd +++++++++++++++++++++++++++++++++++++++++++++++++++++++ Thu Mar 30 17:10:01 2017 > 请打开京东手机客户端,准备扫码登陆: 201 : 二维码未扫描 ,请扫描二维码 201 : 二维码未扫描 ,请扫描二维码 201 : 二维码未扫描 ,请扫描二维码 201 : 二维码未扫描 ,请扫描二维码 202 : 请手机客户端确认登录 200 : BADACIFYhf6fakfHvjiYTlwGzSp4EjFATN3Xw1ePR1hITtw0 登陆成功 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ Thu Mar 30 17:10:28 2017 > 商品详情 编号:3133857 库存:现货 价格:6399.00 名称:Apple iPhone 7 Plus (A1661) 128G 黑色 移动联通电信4G手机 链接:http://cart.jd.com/gate.action?pid=3133857&pcount=1&ptype=1 商品已成功加入购物车! 购买数量:3133857 > 1 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ Thu Mar 30 17:10:30 2017 > 购物车明细 购买 数量 价格 总价 商品 Y 1 6399.00 6399.00 Apple iPhone 7 Plus (A1661) 128G 黑色 移动联通电信4G手机 总数: 1 总额: 6399.00 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ Thu Mar 30 17:10:30 2017 > 订单详情 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ ... ``` ## 注 代码仅供学习之用,京东网页不断变化,代
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值