热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

pythonurllib新浪微博_定向爬虫Python模拟新浪微博登录

阅读目录当我们试图从新浪微博抓取数据时,我们会发现网页上提示未登录,无法查看其他用户的信息。模拟登录是定向爬虫制作中一个必须克服的问题,

阅读目录

当我们试图从新浪微博抓取数据时,我们会发现网页上提示未登录,无法查看其他用户的信息。

模拟登录是定向爬虫制作中一个必须克服的问题,只有这样才能爬取到更多的内容。

实现微博登录的方法有很多,一般我们在模拟登录时首选WAP版。

因为PC版网页源码中包括很多的js代码,提交的内容也更多,不适合机器模拟登录。

我们实现微博登录的大体思路是这样的:

用抓包工具把正常登录时要提交的字段都记录下来;

模拟提交这些字段;

判断是否登录成功;

原理很简单,让我们一步一步来实现吧。

一.抓包利器Fiddler

在电脑和互联网之间的通信是通过不同的数据包收发来实现的。

Fiddler可以从中间对数据进行拦截,拷贝一份数据以后再将数据发送给目的端。(这也是为什么说咖啡馆的公共WIFI不安全的原因)

同类的还有WireShark。为何这儿不用WireShark呢?

Wireshark太过于专业了,它可以实现抓取各种包,抓下来的包也很乱,针对性没Fiddler那么强。

下载安装

2.安装方法:fiddler依赖.Net环境,如果已经有则无需配置,直接点击下一步就行。

使用方法

1.启动Fiddler

2.配置Fiddler

点击左上角的“ WinConfig”,找到你使用的浏览器并勾选,点击“Save Changes”

3.使用Fiddler开始抓包

打开浏览器访问WAP版新浪微博网站weibo.cn

Fiddler窗口左侧找到weibo.cn /pub/的数据包,并双击,这时我们就能够在右侧看到抓取到的信息.

找到COOKIEs字段,这正是我们需要的.

606573-20160301105711689-2146875839.png

二.COOKIEs与保持登录

关于COOKIEs

维基百科是这样解释的:

COOKIE(复数形态COOKIEs),中文名称为“小型文本文件”或“小甜饼”,指某些网站为了辨别用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密)。

通俗来说就是服务器端为了确认用户终端的身份而设定的一种加密标识,它是存储在本地终端上的。

当然,随着COOKIEs技术的发展,COOKIEs的作用已经不止于用户身份标识。

当登陆一个网站时,网站往往会请求用户输入用户名和密码,并且用户可以勾选“下次自动登录”。

如果勾选了,那么下次访问同一个网站时,用户会发现没输入用户名和密码就已经登录了。

这正是因为前一次登陆时服务器发送了包含登录凭据(用户名+密码的某种加密形式)的COOKIE到用户的硬盘上。

第二次登录时,如果该COOKIEs尚未到期,浏览器会发送该COOKIEs,服务器验证凭据,于是不必输入用户名和密码就让用户登录了。

三.COOKIEs模拟登录

下面将介绍使用 Fiddler 获取新浪微博 COOKIEs,然后使用 Requests 提交 COOKIEs 从而实现模拟登录。

抓取登录数据包

使用Fiddler抓取数据包.

获取COOKIEs

打开新浪微博WAP版页面(weibo.cn),点击登录,然后填写账号密码,勾选“记住登录状态”,切记要勾选此项.

登录成功后,从Fiddler中选择最新的那个weibo.cn,然后复制COOKIEs字段的内容,填写到代码内.

代码如下:

copycode.gif

#!/usr/bin/env python

#coding=utf8

""" Simulate a user login to Sina Weibo with COOKIE.

You can use this method to visit any page that requires login.

"""

import urllib2

import re

# get your COOKIE from Fiddler11

COOKIE = 'your-COOKIE'

headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; rv:24.0) Gecko/20100101 Firefox/24.0',

'COOKIE': COOKIE

}

def visit():

url = 'http://weibo.com'

req = urllib2.Request(url, headers=headers)

text = urllib2.urlopen(req).read()

# print the title, check if you login to weibo sucessfully

pat_title = re.compile('

(.+?)')

r = pat_title.search(text)

if r:

print(r.group(1))

if __name__ == '__main__':

visit()

copycode.gif

四.使用 Post 提交数据的方法实现模拟登录

由于使用COOKIEs登录存在很多的弊端,一般我们都使用Post提交数据的方法来实现模拟登录.

通过Fiddler来抓取http数据包来分析该网站的登录流程;

分析抓到的post包的数据结构和header,要根据提交的数据结构和heander来构造自己的post数据和header;

构造自己的HTTP数据包,并发送给指定url;

通过urllib2等几个模块提供的API来实现request请求的发送和相应的接收;

大部分网站登录时需要携带COOKIE,所以我们还必须设置COOKIE处理器来保证COOKIE.

notice:如果遇到登录后网站重定向到其他url这种情况,我们可以使用chrome的审查元素功能找出重定向后的网站url和该网站的提交数据,再次使用post方法就行.

代码如下:

copycode.gif

#!/usr/bin/python

import HTMLParser

import urlparse

import urllib

import urllib2

import COOKIElib

import string

import re

#登录的主页面

hosturl = '******' //自己填写

#post数据接收和处理的页面(我们要向这个页面发送我们构造的Post数据)

posturl = '******' //从数据包中分析出,处理post请求的url

#设置一个COOKIE处理器,它负责从服务器下载COOKIE到本地,并且在发送请求时带上本地的COOKIE

cj = COOKIElib.LWPCOOKIEJar()

COOKIE_support = urllib2.HTTPCOOKIEProcessor(cj)

opener = urllib2.build_opener(COOKIE_support, urllib2.HTTPHandler)

urllib2.install_opener(opener)

#打开登录主页面(他的目的是从页面下载COOKIE,这样我们在再送post数据时就有COOKIE了,否则发送不成功)

h = urllib2.urlopen(hosturl)

#构造header,一般header至少要包含一下两项。这两项是从抓到的包里分析得出的。

headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:14.0) Gecko/20100101 Firefox/14.0.1',

'Referer' : '******'}

#构造Post数据,他也是从抓大的包里分析得出的。

postData = {'op' : 'dmlogin',

'f' : 'st',

'user' : '******', //你的用户名

'pass' : '******', //你的密码

'rmbr' : 'true', //特有数据,不同网站可能不同

'tmp' : '0.7306424454308195' //特有数据,不同网站可能不同

}

#需要给Post数据编码

postData = urllib.urlencode(postData)

#通过urllib2提供的request方法来向指定Url发送我们构造的数据,并完成登录过程

request = urllib2.Request(posturl, postData, headers)

print request

response = urllib2.urlopen(request)

text = response.read()

print text

copycode.gif



推荐阅读
  • HTTP(超文本传输协议)是互联网上用于客户端和服务器之间交换数据的主要协议。本文详细介绍了HTTP的工作原理,包括其请求-响应机制、不同版本的发展历程以及HTTP数据包的具体结构。 ... [详细]
  • 本文详细介绍了如何在Android应用中处理和使用Cookie,包括登录时获取Cookie并将其存储,以及在WebView中同步这些Cookie以保持用户会话。 ... [详细]
  • 这是一个基于 React 构建的掘金移动版应用,主要模仿了掘金的 UI 设计,并进行了部分自定义调整。项目专注于移动端体验,同时支持服务端渲染和渐进式网络应用(PWA)功能。 ... [详细]
  • 本文探讨了在使用Apache HttpClient 4.x(作为commons-httpclient 3.x的后续版本)时,如何配置默认的HttpContext,以确保每次执行请求时无需显式传递上下文。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细探讨了在微服务架构中,使用Feign进行远程调用时出现的请求头丢失问题,并提供了具体的解决方案。重点讨论了单线程和异步调用两种场景下的处理方法。 ... [详细]
  • 探索Squid反向代理中的远程代码执行漏洞
    本文深入探讨了在网站渗透测试过程中发现的Squid反向代理系统中存在的远程代码执行漏洞,旨在帮助网站管理者和开发者了解此类漏洞的危害及防范措施。 ... [详细]
  • 随着技术的发展,黑客开始利用AI技术在暗网中创建用户的‘数字孪生’,这一现象引起了安全专家的高度关注。 ... [详细]
  • 本文将详细介绍Python中一个非常实用的HTTP客户端库——requests模块,它不仅易于使用,而且功能强大,非常适合用于开发网络应用或进行Web数据抓取。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 为了深入了解辽源市市民对智能城市建设的感受和建议,国家统计局辽源调查队近期开展了一项针对200位市民的问卷调查。结果显示,大部分市民对智能城市的认知度较高,并对其带来的便利表示肯定。 ... [详细]
  • 请看|差别_Android 6.0 运行时权限处理解析
    请看|差别_Android 6.0 运行时权限处理解析 ... [详细]
author-avatar
Rosalind33
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有