本文转载自以下链接:https://www.makcyun.top/web_scraping_withpython8.html

目的是万一博主网站无法访问到的话自己需要学习的东西可就不存在了.

本文需要学习的地方,使用三种不同的方式爬取需要登录才能获取数据的网站数据

POST 请求方法:需要在后台获取登录的 URL并填写请求体参数,然后 POST 请求登录,相对麻烦;

添加 Cookies 方法:先登录将获取到的 Cookies 加入 Headers 中,最后用 GET 方法请求登录,这种最为方便;

Selenium 模拟登录:代替手工操作,自动完成账号和密码的输入,简单但速度比较慢。

对于很多要先登录的网站来说,模拟登录往往是爬虫的第一道坎。本文介绍 POST 请求登录、获取 Cookies 登录、Seleium 模拟登录三种方法。

摘要: 在进行爬虫时,除了常见的不用登录就能爬取的网站,还有一类需要先登录的网站。比如豆瓣、知乎,以及上一篇文章中的桔子网。这一类网站又可以分为:只需输入帐号密码、除了帐号密码还需输入或点击验证码等类型。本文以只需输入账号密码就能登录的桔子网为例,介绍模拟登录常用的 3 种方法。

POST 请求方法:需要在后台获取登录的 URL并填写请求体参数,然后 POST 请求登录,相对麻烦;

添加 Cookies 方法:先登录将获取到的 Cookies 加入 Headers 中,最后用 GET 方法请求登录,这种最为方便;

Selenium 模拟登录:代替手工操作,自动完成账号和密码的输入,简单但速度比较慢。

下面,我们用代码分别实现上述 3 种方法。

1. 目标网页

这是我们要获取内容的网页:

这个网页需要先登录才能看到数据信息,登录界面如下:

可以看到,只需要输入账号和密码就可以登录,不用输验证码,比较简单。下面我们利用一个测试账号和密码,来实现模拟登录。

2. POST 提交请求登录

首先,我们要找到 POST 请求的 URL。

有两种方法,第一种是在网页 devtools 查看请求,第二种是在 Fiddler 软件中查看。

先说第一种方法。

在登录界面输入账号密码,并打开开发者工具,清空所有请求,接着点击登录按钮,这时便会看到有大量请求产生。哪一个才是 POST 请求的 URL呢?这个需要一点经验,因为是登录,所以可以尝试点击带有 「login」字眼的请求。这里我们点击第四个请求,在右侧 Headers 中可以看到请求的 URL,请求方式是 POST类型,说明 URL 找对了。

接着,我们下拉到 Form Data,这里有几个参数,包括 identify 和 password,这两个参数正是我们登录时需要输入的账号和密码,也就是 POST 请求需要携带的参数。

参数构造非常简单,接下来只需要利用 Requests.post 方法请求登录网站,然后就可以爬取内容了。

下面,我们尝试用 Fiddler 获取 POST 请求。

如果你对 Fiddler 还不太熟悉或者没有电脑上没有安装,可以先了解和安装一下。

Fiddler 是位于客户端和服务器端的 HTTP 代理,也是目前最常用的 HTTP 抓包工具之一 。 它能够记录客户端和服务器之间的所有 HTTP 请求,可以针对特定的 HTTP 请求,分析请求数据、设置断点、调试 web 应用、修改请求的数据,甚至可以修改服务器返回的数据,功能非常强大,是 web 调试的利器。

Fiddler 下载地址:

使用教程:

下面,我们就通过 Fiddler 截取登录请求。

当点击登录时,官场 Fiddler 页面,左侧可以看到抓取了大量请求。通过观察,第15个请求的 URL中含有「login」字段,很有可能是登录的 POST 请求。我们点击该请求,回到右侧,分别点击「inspectors」、「Headers」,可以看到就是 POST 请求,该 URL 和上面的方法获取的 URL 是一致的。

接着,切换到右侧的 Webforms 选项,可以看到 Body 请求体。也和上面方法中得到的一致。

获取到 URL 和请求体参数之后,下面就可以开始用 Requests.post 方法模拟登录了。

代码如下:

import requests

headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.181 Safari/537.36',

}

data = {

'identity':'irw27812@awsoo.com',

'password':'test2018',

}

url ='https://www.itjuzi.com/user/login?redirect=&flag=&radar_coupon='

session = requests.Session()

session.post(url,headers = headers,data = data)

# 登录后,我们需要获取另一个网页中的内容

response = session.get('http://radar.itjuzi.com/investevent',headers = headers)

print(response.status_code)

print(response.text)

使用 session.post 方法提交登录请求,然后用 session.get 方法请求目标网页,并输出 HTML代码。可以看到,成功获取到了网页内容。

下面,介绍第 2 种方法。

3. 获取 Cookies,直接请求登录

上面一种方法,我们需要去后台获取 POST 请求链接和参数,比较麻烦。下面,我们可以尝试先登录,获取 Cookie,然后将该 Cookie 添加到 Headers 中去,然后用 GET 方法请求即可,过程简单很多。

代码如下:

import requests

headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.181 Safari/537.36',

'Cookie': '你的cookie',

}

url = 'https://www.itjuzi.com/user/login?redirect=&flag=&radar_coupon='

session = requests.Session()

response = session.get('http://radar.itjuzi.com/investevent', headers=headers)

print(response.status_code)

print(response.text)

可以看到,添加了 Cookie 后就不用再 POST 请求了,直接 GET 请求目标网页即可。可以看到,也能成功获取到网页内容。

下面介绍第 3 种方法。

4. Selenium 模拟登录

这个方法很直接,利用 Selenium 代替手动方法去自动输入账号密码然后登录就行了。

关于 Selenium 的使用,在之前的一篇文章中有详细介绍,如果你不熟悉可以回顾一下:

代码如下:

from selenium import webdriver

from selenium.webdriver.common.by import By

from selenium.webdriver.support import expected_conditions as EC

from selenium.webdriver.support.wait import WebDriverWait

browser = webdriver.Chrome()

browser.maximize_window() # 最大化窗口

wait = WebDriverWait(browser, 10) # 等待加载10s

def login():

browser.get('https://www.itjuzi.com/user/login')

input = wait.until(EC.presence_of_element_located(

(By.XPATH, '//*[@id="create_account_email"]')))

input.send_keys('irw27812@awsoo.com')

input = wait.until(EC.presence_of_element_located(

(By.XPATH, '//*[@id="create_account_password"]')))

input.send_keys('test2018')

submit = wait.until(EC.element_to_be_clickable(

(By.XPATH, '//*[@id="login_btn"]')))

submit.click() # 点击登录按钮

get_page_index()

def get_page_index():

browser.get('http://radar.itjuzi.com/investevent')

try:

print(browser.page_source) # 输出网页源码

except Exception as e:

print(str(e))

login()

这里,我们在网页中首先定位了账号节点位置:'//*[@id="create_account_email"]',然后用 input.send_keys 方法输入账号,同理,定位了密码框位置并输入了密码。接着定位 登录 按钮的位置://*[@id="login_btn"],然后用 submit.click() 方法实现点击登录按钮操作,从而完成登录。可以看到,也能成功获取到网页内容。

以上就是模拟需登录网站的几种方法。当登录进去后,就可以开始爬取所需内容了。

5. 总结:

本文分别实现了模拟登录的 3 种操作方法,建议优先选择第 2 种,即先获取 Cookies 再 Get 请求直接登录的方法。

本文模拟登录的网站,仅需输入账号密码,不需要获取相关加密参数,比如 Authenticity_token ,同时也无需输入验证码,所以方法比较简单。但是还有很多网站模拟登录时,需要处理加密参数、验证码输入等问题。后续将会介绍。

python登录网站后爬取数据_需要登陆网站后才能获取数据的页面爬取相关推荐

  1. android 简单获取实时天气数据_绘图本身很简单但是获取数据很难

    看到我们生信技能树的教学群有学员提问这样的图如何绘制: 其实我们讲解过,绘图代码本身搜索即可拿到,关键词 ggpubr paired boxplot ,输入到 https://cn.bing.com/ ...

  2. 利用串口网络助手上传数据、图片到OneNet平台以及获取数据(HTTP)

    利用串口网络助手上传数据.图片到OneNet平台以及获取数据(HTTP) 使用网络助手连接OneNet服务器 HTTP上传数据至OneNet 获取数据 上传图片至OneNet 使用网络助手连接OneN ...

  3. vue 读取ajax数据,详解vue 中使用 AJAX获取数据的方法

    在VUE开发时,数据可以使用jquery和vue-resource来获取数据.在获取数据时,一定需要给一个数据初始值. 看下例: new Vue({ el:'#app', data:{data:&qu ...

  4. python爬取今日头条后台数据_Python爬虫实战入门五:获取JS动态内容—爬取今日头条...

    之前我们爬取的网页,多是HTML静态生成的内容,直接从HTML源码中就能找到看到的数据和内容,然而并不是所有的网页都是这样的. 有一些网站的内容由前端的JS动态生成,由于呈现在网页上的内容是由JS生成 ...

  5. 网站爬取工具_浅析阻碍网站内容被蜘蛛抓取的原因有哪些?

    众所周知,在搜索引擎中存在的蜘蛛其实就是一段代码,这段代码通过在各个网站爬取,以便于网站内容能够被搜索引擎收录.不过一般蜘蛛爬取是按照一定规则进行的,如果网站中出现了一些爬取障碍,那么蜘蛛爬取就会被打 ...

  6. python爬虫未来发展前景好的行业_爬虫实战2:招聘大数据告诉你运营岗需求现状及职业发展前景...

    写在前面的话 到今年7月份,我就将正式成为一个4岁的运营人啦!相信对于很多运营同学来说,都会思考自己的职业发展路径和规划.还记得我刚入行时,公司的前辈跟我们分享,建议大家要隔一段时间关注下招聘市场的行 ...

  7. bootstraptable 怎么在特定行添加数据_手把手教你做一个“渣”数据师,用Python代替老情人Excel...

    大数据文摘出品 来源:medium 编译:张大笔茹 十年前,你说你是做数据的,大家的反应就是 -- 用 Excel 做做表. 现在,要成为一个合格的数据分析师,你说你不会 Python,大概率会被江湖 ...

  8. python打不开文件数据恢复软件_使用数据恢复软件后文件打不开是什么原因?

    电脑磁盘误删了文件或磁盘误格式化导致文件丢失,用数据恢复软件进行恢复,恢复出来的WORD文件.图像等文件有时会出现打不开的情况,下面就来分析下原因. 打不开的原因: 1.文件删除后,在该文件所在磁盘中 ...

  9. 未越狱设备提取数据_从三星设备中提取健康数据

    未越狱设备提取数据 Health data is collected every time you have your phone in your pocket. Apple or Android, ...

最新文章

  1. Win7访问局域网内共享文件夹
  2. asp.net中的MD5加密
  3. 爬取许嵩新歌《雨幕》弹幕,告诉你什么才是真正的创作!
  4. Android QEMU 高速管道
  5. 一步步实现windows版ijkplayer系列文章之一Windows10平台编译ffmpeg 4.0.2,生成ffplay
  6. 利用BS爬取单词音标
  7. python猜数字十次、猜对输出猜了多少次_python-猜数字小练习
  8. DDR123信号完整性测试分析技术探析
  9. 可正常访问的 高校2.5D 地图
  10. Log4j史诗级漏洞,我们这些小公司能做些什么?
  11. 云计算主要包含哪些基本特征?
  12. 【编程测试题】头条校招
  13. 浏览器指纹技术与浏览器指纹破解办法
  14. JAVA高并发多线程必须懂的50个问题
  15. 记某环境SqlServer异地备份的坑(Server权限管控贼拉严格)
  16. 使用PyTorch进行知识蒸馏的代码示例
  17. Chrome浏览器启动命令行参数
  18. python loadlibrary_使用py2exe教程时出现LoadLibrary(pythondll)失败错误
  19. 进化算法及Python实现(使用DEAP库)
  20. 解决Mac USB口电压不足问题

热门文章

  1. Cisco考试再认证常见疑难问题解答
  2. 定位导航算法高级框架设计
  3. zuul网关转发丢失头信息问题
  4. 测试用例的力度和评审、测试用例的本质
  5. IDENTITY属性的使用详解
  6. Vue的双向数据绑定原理是什么
  7. 计算机毕业设计asp.net考试安排管理系统VS开发sqlserver数据库web结构c#编程计算机网页源码项目
  8. freenom免费域名申请及设置域名解析
  9. 电路学习笔记(单项变压器极性判断)
  10. 马斯克的收购让员工感到恐慌 CEO安抚称公司不会被“挟持”