python 实现登录网页的操作

本文 Github/javamap 已收录,有Java程序员进阶技术知识地图以及我的系列文章,欢迎大家Star。

 

场景

有些网页需要你登录之后才可以访问,你需要提供账户和密码。

只要在发送http请求时,带上含有正常登陆的cookie就可以了。

 

 

首先我们要先了解cookie的工作原理。

Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是浏览器设置为启用cookie)。

 

Cookie名称和值可以由服务器端开发自己定义,对于JSP而言也可以直接写入jsessionid,这样服务器可以知道该用户是否合法用户以及是否需要重新登录等。

 

 

之后我们要获取到用户正常登录的cookie.

python提供了cookieJar的库,只要把cookieJar的实例作为参数传到urllib2的一个opener里面。

然后访问一次登录的页面,cookie就已经保存下来了。

之后通过这个实例访问所有的页面都带有正常登陆的cookie了。

这里以人人网为例子:

Python代码

 

完整代码,可直接复制到编辑器使用

  1. #encoding=utf-8  
  2. import urllib2  
  3. import urllib  
  4. import cookielib  
  5. def renrenBrower(url,user,password):  
  6.     #登陆页面,可以通过抓包工具分析获得,如fiddler,wireshark 
  7.     login_page = "http://www.renren.com/PLogin.do"  
  8.     try:  
  9.         #获得一个cookieJar实例  
  10.         cj = cookielib.CookieJar()  
  11.         #cookieJar作为参数,获得一个opener的实例  
  12.         opener=urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))  
  13.         #伪装成一个正常的浏览器,避免有些web服务器拒绝访问。  
  14.         opener.addheaders = [('User-agent','Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)')]  
  15.         #生成Post数据,含有登陆用户名密码。  
  16.         data = urllib.urlencode({"email":user,"password":password})  
  17.         #以post的方法访问登陆页面,访问之后cookieJar会自定保存cookie  
  18.         opener.open(login_page,data)  
  19.         #以带cookie的方式访问页面  
  20.         op=opener.open(url)  
  21.         #读取页面源码  
  22.         data= op.read()  
  23.         return data  
  24.     except Exception,e:  
  25.         print str(e)  
  26. #访问某用户的个人主页,其实这已经实现了人人网的签到功能。  
  27. print renrenBrower("http://www.renren.com/home","用户名","密码"

 

 

-- END --

日常求赞:你好技术人,先赞后看养成习惯,你的赞是我前进道路上的动力,对我非常重要。

加油技术人!

简介: 博主从华中科技大学硕士毕业,是一个对技术有追求,对生活有激情的程序员。几年间浪迹于多个一线互联网大厂,具有多年开发实战经验。

微信搜索公众号【爱笑的架构师】,我有技术和故事,等你来。

文章持续更新,在 Github/javamap 中可以看到我归档的系列文章,有面试经验和技术干货,欢迎Star。

 

  • 4
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值