网页爬虫之cookie自动获取及过期自动更新的实现方法

前端之家收集整理的这篇文章主要介绍了网页爬虫之cookie自动获取及过期自动更新的实现方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实现cookie的自动获取,及cookie过期自动更新。

社交网站中的很多信息需要登录才能获取到,以微博为例,不登录账号,只能看到大V的前十条微博。保持登录状态,必须要用到Cookie。以登录 为例:

在chrome中输入:

分析控制台的Headers的请求返回,会看到weibo.cn有几组返回的cookie。

实现步骤:

1,采用selenium自动登录获取cookie,保存到文件;

2,读取cookie,比较cookie的有效期,若过期则再次执行步骤1;

3,在请求其他网页时,填入cookie,实现登录状态的保持。

1,在线获取cookie

采用selenium + PhantomJS 模拟浏览器登录获取cookie;

cookies一般会有多个,逐个将cookie存入以.weibo后缀的文件

登录 # 获得 cookie信息 cookie_list = driver.get_cookies() print cookie_list cookie_dict = {} for cookie in cookie_list: #写入文件 f = open(cookie['name']+'.weibo','w') pickle.dump(cookie,f) f.close() if cookie.has_key('name') and cookie.has_key('value'): cookie_dict[cookie['name']] = cookie['value'] return cookie_dict

2,从文件获取cookie

从当前目录中遍历以.weibo结尾的文件,即cookie文件。采用pickle解包成dict,比较expiry值与当前时间,若过期则返回为空;

(int)(time.time()): cookie_dict[d['name']] = d['value'] else: return {} return cookie_dict

3,若缓存cookie过期,则再次从网络获取cookie

4,带cookie请求微博其他主页

总结

以上所述是小编给大家介绍的网页爬虫之cookie自动获取及过期自动更新的实现方法。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

猜你在找的JavaScript相关文章