python脚本根据cookies自动登录网站_Python爬虫利用cookie实现模拟登陆实例详解

news/2024/5/18 14:41:46/文章来源:https://blog.csdn.net/weixin_39630880/article/details/109878499

Cookie,指某些网站为了辨别用户身份、进行session跟踪而储存在用户本地终端上的数据(通常经过加密)。

举个例子,某些网站是需要登录后才能得到你想要的信息的,不登陆只能是游客模式,那么我们可以利用Urllib2库保存我们以前登录过的Cookie,之后载入cookie获取我们想要的页面,然后再进行抓取。理解cookie主要是为我们快捷模拟登录抓取目标网页做出准备。

我之前的帖子中使用过urlopen()这个函数来打开网页进行抓取,这仅仅只是一个简单的Python网页打开器,其参数也仅有urlopen(url,data,timeout),这三个参数对于我们获取目标网页的cookie是远远不够的。这时候我们就要利用到另外一种Opener——CookieJar。

cookielib也是Python进行爬虫的一个重要模块,他能与urllib2相互结合一起爬取想要的内容。该模块的CookieJar类的对象可以捕获cookie并在后续连接请求时重新发送,这样就可以实现我们所需要的模拟登录功能。

这里特别说明一下,cookielib是在py2.7中自带的模块,无需重新安装,想要查看其自带模块可以查看Python目录下的Lib文件夹,里面有所有安装的模块。我一开始没想起来,在pycharm中竟然没有搜到cookielib,使用了快捷安装也报错:Couldn't find index page for 'Cookielib' (maybe misspelled?)

201701121014243.png

之后才想起来是不是自带的就有,没想到去lib文件夹一看还真有,白白浪费半个小时各种瞎折腾~~

下面我们就来介绍一下这个模块,该模块主要的对象有CookieJar、FileCookieJar、MozillaCookieJar、LWPCookieJar。

它们的关系:CookieJar —-派生—->FileCookieJar —-派生—–>MozillaCookieJar和LWPCookieJar 主要用法,我们下面也会讲到。urllib2.urlopen()函数不支持验证、cookie或者其它HTTP高级功能。要支持这些功能,必须使用build_opener()(可以用于让python程序模拟浏览器进行访问,作用你懂得~)函数创建自定义Opener对象。

1、首先我们就来获取一下网站的cookie

例子:

#coding=utf-8

import cookielib

import urllib2

mycookie = cookielib.CookieJar() #声明一个CookieJar的类对象保存cookie(注意CookieJar的大小写问题)

handler = urllib2.HTTPCookieProcessor(mycookie) #利用urllib2库中的HTTPCookieProcessor来声明一个处理cookie的处理器

opener = urllib2.build_opener(handler) #利用handler来构造opener,opener的用法和urlopen()类似

response = opener.open("http://www.baidu.com") #opener返回的一个应答对象response

for item in my.cookie:

print"name="+item.name

print"value="+item.value

结果:

name=BAIDUID

value=73BD718962A6EA0DAD4CB9578A08FDD0:FG=1

name=BIDUPSID

value=73BD718962A6EA0DAD4CB9578A08FDD0

name=H_PS_PSSID

value=1450_19035_21122_17001_21454_21409_21394_21377_21526_21189_21398

name=PSTM

value=1478834132

name=BDSVRTM

value=0

name=BD_HOME

value=0

这样我们就得到了一个最简单的cookie。

2、将cookie保存到文件

上面我们得到了cookie,下面我们学习如何保存cookie。在这里我们使用它的子类MozillaCookieJar来实现Cookie的保存

例子:

#coding=utf-8

import cookielib

import urllib2

mycookie = cookielib.MozillaCookieJar() #声明一个MozillaCookieJar的类对象保存cookie(注意MozillaCookieJar的大小写问题)

handler = urllib2.HTTPCookieProcessor(mycookie) #利用urllib2库中的HTTPCookieProcessor来声明一个处理cookie的处理器

opener = urllib2.build_opener(handler) #利用handler来构造opener,opener的用法和urlopen()类似

response = opener.open("http://www.baidu.com") #opener返回的一个应答对象response

for item in mycookie:

print"name="+item.name

print"value="+item.value

filename='mycookie.txt'#设定保存的文件名

mycookie.save(filename,ignore_discard=True, ignore_expires=True)

将上面的例子简单变形就可以得到本例,使用了CookieJar的子类MozillaCookiJar,为什么呢?我们将MozillaCookiJar换成CookieJar试试,下面一张图你就能明白:

201701121014254.png

CookieJar是没有保存save属性的~

save()这个方法中:ignore_discard的意思是即使cookies将被丢弃也将它保存下来,ignore_expires的意思是如果在该文件中cookies已经存在,则覆盖原文件写入,在这里,我们将这两个全部设置为True。运行之后,cookies将被保存到cookie.txt文件中,我们查看一下内容:

201701121014255.png

这样我们就成功保存了我们想要的cookie

3、从文件中获取cookie并访问


#coding=utf-8

import urllib2

import cookielib

import urllib

#第一步先给出账户密码网址准备模拟登录

postdata = urllib.urlencode({

'stuid': '1605122162',

'pwd': 'xxxxxxxxx'#密码这里就不泄漏啦,嘿嘿嘿

})

loginUrl = 'http://ids.xidian.edu.cn/authserver/login?service=http%3A%2F%2Fjwxt.xidian.edu.cn%2Fcaslogin.jsp'# 登录教务系统的URL,成绩查询网址

# 第二步模拟登陆并保存登录的cookie

filename = 'cookie.txt' #创建文本保存cookie

mycookie = cookielib.MozillaCookieJar(filename) # 声明一个MozillaCookieJar对象实例来保存cookie,之后写入文件

opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(mycookie)) #定义这个opener,对象是cookie

result = opener.open(loginUrl, postdata)

mycookie.save(ignore_discard=True, ignore_expires=True)# 保存cookie到cookie.txt中

# 第三步利用cookie请求访问另一个网址,教务系统总址

gradeUrl = 'http://ids.xidian.edu.cn/authserver/login?service' #只要是帐号密码一样的网址就可以, 请求访问成绩查询网址

result = opener.open(gradeUrl)

print result.read()






创建一个带有cookie的opener,在访问登录的URL时,将登录后的cookie保存下来,然后利用这个cookie来访问其他网址。


核心思想:创建opener,包含了cookie的内容。之后在利用opener时,就会自动使用原先保存的cookie.


感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_752562.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站统计中的数据收集原理及实现

网站数据统计分析工具是网站站长和运营人员经常使用的一种工具,比较常用的有谷歌分析、百度统计和腾讯分析等等。所有这些统计分析工具的第一步都是网站访问数据的收集。目前主流的数据收集方式基本都是基于javascript的。本文将简要分析这种数据收集的原理&#xf…

理解mouseover,mouseout,mouseenter,mouseleave

mouseover定义和用法 当鼠标指针位于元素上方时,会发生 mouseover 事件。 该事件大多数时候会与 mouseout 事件一起使用。 mouseover() 方法触发 mouseover 事件,或规定当发生 mouseover 事件时运行的函数。 注释:与 mouseenter 事件不同&…

pdf在线翻译_PDF文件怎么翻译?有了这个网站,100页英文秒转中文

同学们在网上找外文文献的时候有没有这样的烦恼?下载下来外文文献很多都是PDF格式的,要翻译的时候简直头都秃了,不能复制,而且还有很多专业词汇特别难懂!那么PDF文件要怎么快速翻译呢?别急,今天…

xbwseo_admin.php,小霸王系统SEO站群v6.3免授权无限制版带安装教程

菜鸟源码分享最新价值600元的小霸王SEO站群v6.3免授权无限制版安装教程,好源码站长测试源码安装和后台的功能保存正常,添加网站域名和前端展示正常。一、系统需求基本需求:php 伪静态(必须)配置:系统: windows/linuxweb服务器: i…

java编写一个为网站生成验证码的程序_Java后端产生验证码后台验证功能的实现代码...

直接跳severlet在java后台生成验证码:RequestMapping(value"yzm.action")public void Yzm(HttpSession session,HttpServletResponse resp){// 验证码图片的宽度。int width 60;// 验证码图片的高度。int height 20;// 验证码字符个数int codeCount 4;…

php网站目录分配,windows+nginx配置站点目录发生500的一个问题

用phpstudy配置一个站点的时候,发现一直报错500,后来查看了下error.log.报错如下:而phpstudy站点配置如下:server {listen 80;server_name www.cn ;root "F:\work\www\test_for_windows";location / {index index.html index.htm index.php;#autoindex on…

云服务器 cvm mysql_腾讯云服务器建站系列 - 腾讯云CVM选择以及系统安装篇

老蒋前天遇到一个比较小白的网友,估计之前从来没有建站过,然后不懂为何还购买了腾讯云服务器。而且,服务器中什么都没有安装,只是在本地电脑中可以打开PHPSTUDY测试环境搭建的网站,问怎么无法打开域名直接打开服务器的…

ep by Step WebMatrix网站开发之一:Webmatrix安装

WebMatrix是微软提供的一个完全免费的Web开发工具,工具内已集成web服务器、数据库和程序架构。笔者最感兴趣的是新的Razor,一个ASP.NET新的视图引擎。该引擎很好的将服务器代码和HTML代码融合在一起,使代码非常容易阅读和理解,而且…

寻找网页设计灵感的200佳网站推荐(系列一)

这个系列将向大家分享寻找网页设计灵感的200佳网站。网页设计师们可通过这些网站收集的优秀网页设计作品来获取灵感,进而设计出更加时尚、更有创意的作品,网页设计师也可以把自己得意的作品提交到这些网站,分享给其它的设计师朋友。如果你有收…

25个国外优秀电子商务网站设计案例

这篇文章与大家分享25个国外优秀的电子商务网站设计案例,希望能带给你灵感。对于电子商务网站来说,也许销售更多产品比漂亮的外观设计更重要,不过漂亮的东西总是能给用户留下深刻的印象,一起欣赏。 Jethro & Jackson Juicy Co…

.NET4.0下网站应用程序用UrlRewriter.dll重写无后缀路径 (在IIS7.5中的配置方法)

接上一篇 .NET4.0下网站应用程序用UrlRewriter.dll重写无后缀路径 在IIS中新建网站(端口号8111) 直接运行http://localhost:8111/ 错误截图 配置方法: 二、添加通配符脚本映射,选择:C:\Windows\Microsoft.NET\Framewo…

php mysql 网站性能分析工具_如何使用工具进行线上 PHP 性能追踪及分析?

工作了一两年的 PHPer 大概都多多少少知道一些性能分析的工具,比如 Xdebug、xhprof、New Relic 、OneAPM。使用基于 Xdebug 进行 PHP 的性能分析,对于本地开发环境来说是够用了,但如果是线上环境的话,xdebug 消耗较大,…

8个超棒的学习 jQuery 的网站[转]

转自:http://xcodebox.com/thread-4179.html 国外科技网站 W3Techs 一项调查了近100万个网站数据显示,jQuery是目前最流行的 JavaScript 库。对于初学者来说,有的时候很难找到一个好的学习jQuery的网站,所以本文收集了8个很棒的 j…

网络营销第五课(4):SEO搜索引擎优化(友链交换)

上次讲了交换链接的注意事项,今天我来介绍交换链接有哪些途径? 1、个人关系。新网站没有PR值、没有排名、没有流量,所以肯定没人愿意和你换了。所以这个时候只能靠个人关系了,有时候为了生存,只能先把面子放兜里了。 2…

网站服务器崩溃原因,云服务器网站崩溃的原因

云服务器网站崩溃的原因 内容精选换一换请根据您的实际情况,选择用于备案的服务器,并单击“验证”。备案授权码是由弹性云服务器(含云耀云服务器)生成的用于备案的授权凭证,实际指向该服务器的IP地址。对于跨帐号的云资源类型,您可…

世界知名网站的技术实现(转)

网站需要具有良好的可伸缩性,来应对不断增长的访问量和数据量。《程序员》杂志5月刊的《可伸缩性的10年探索:知名网站的技术发展历程》一文中介绍了一些Alexa排名较前的网站的技术发展历程,本文将结合提及的Google、Facebook、Twitter等网站的…

提高网站速度|如何利用缓存

文章出处:http://hi.baidu.com/%CF%F2%CD%F9%BC%BE%BA%F3%C8%FC/blog/item/0f93cffcb5a12743d7887d63.html最近开始关注速度问题。 ASP.NET提供三种主要形式的缓存:页面级输出缓存、用户控件级输出缓存(或称为片段缓存)和缓存A…

夺宝网站服务器配置,3月27日服务器公告:夺宝小分队

2015年3月25日寻宝小分队计划了一系列的海洋冒险,本周它们将会进行一次深海航行。跟随绿麟小子一起去经历热血的航海冒险吧!剧情更新藏宝地库的敌人根据藏宝图指示,大家来到了藏宝地库,这里会找到宝藏吗?最新活动1.深海…

网站安全加固之apache环境S2-057漏洞 利用POC 远程执行命令漏洞复现

2019独角兽企业重金招聘Python工程师标准>>> S2-057漏洞,于2018年8月22日被曝出,该Struts2 057漏洞存在远程执行系统的命令,尤其使用linux系统,apache环境,影响范围较大,危害性较高,…

我有一个网站,想提高点权重

我有一个网站,想提高点权重很多创业者在新建立一个网站却不知道如何推广优化。今天松松团队就通过这篇文章来给大家做个介绍。网站的推广和优化我们要遵循“先总体后细节”的方式。也就是说,我们应该先确立“网站总体运营指标”也就是先设置一个目标&…