什么是Http和Https

  • http协议:全称是HyperText Transfer Protocol,中文意思是超文本传输协议,是一种发布和接收Html页面的方法。默认的端口号是80
  • https协议:是http协议的加密版本,在HTTP下加入了SSL层。服务器端口号是443

在浏览器中发送一个Http请求的过程

  1. 当用户在浏览器的地址栏输入一个url并点下确定键时,浏览器会向web服务器发送HTTP请求,HTTP请求主要有GET和POST两种方法
  2. 发送过request请求后,服务器会返回一个response文件对象给浏览器
  3. 浏览器分析response中的HTML,如果其中引入了其他的一些文件(css文件,js文件,等等)浏览器会自动再次发送request请求去获取这些文件
  4. 当所有的文件都下载下来以后,网页会根据html的语法,在页面上完整的显示出来

URL的一些讲解

URL:(Uniform Resource Locator的缩写),统一资源定位符。一个url的组成:

scheme://host:port/path/?key=value
  • scheme:代表访问协议,一般为http或者https以及ftp等等
  • host:主机名,域名
  • port:端口号,当你访问一个网站的时候,默认的就是80端口
  • path:查找的路径
  • key=value:get请求的参数

在浏览器中请求一个url,浏览器会对这个url进行一个编码。除了英文字母,数字和部分符号以外,其他的全部使用百分号+十六进制码值进行编码

常用的请求方式

在Http协议中定义了八种请求方式,这里介绍两种最常用的

  • get请求:一般情况下,只从服务器获取数据下来,并不会对服务器资源产生影响的时候我们用GET,GET请求的参数在url后面使用?隔开,参数之间用&隔开
  • post请求:向服务器发送数据(登录)、上传文件等,会对服务其的资源产生影响的时候使用POST请求,请求的数据在请求体当中。

请求头中的常见的参数

在http协议中,向服务器发送一个请求,数据分为三个部分,把数据放在url中(get请求)、把数据放在body请求体当中(post请求)、把数据放在head中。

  • User-Agent:浏览器的标识。如果我们不填写的话,默认的爬虫的User-Agent就是Python,浏览器可以轻易知道你是一个爬虫,所以建议每次都带上User-Agent
  • Referer:表明当前这个请求是从哪一个url过来的。这个一般也可以做成反扒的,如果不是指定的url跳转过来的就返回一个假数据
  • Cookie:http协议是无状态协议,也就是说,同一个人发送来个请求,服务器是无法分辨是一个人发送的还是两个人发送的,因此就有了cookie作为一个标识,标识是我,我们做登录的时候必须用到Cookie

常见的一些状态码

  • 200:请求正常,也就是成功
  • 301:永久重定向,也就是说服务器指定的跳转页面、
  • 302:临时重定向,eg:有些页面必须登录才能访问,而你没有登录,就会跳转到登录的页面
  • 400:找不到
  • 403:服务器拒绝访问,权限不够,在Django中,Post请求的时候,总会有一个csrf_token 的东西,如果没有的,而服务器有开启的csrf的中间件,呵,妥妥的403
  • 500:服务器的内部错误,也就是服务器出BUG了

Python爬虫学习:一些关于爬虫的知识的充电的更多相关文章

  1. Python 基于学习 网络小爬虫

    <span style="font-size:18px;"># # 百度贴吧图片网络小爬虫 # import re import urllib def getHtml( ...

  2. python基础学习1-网络爬虫程序中的代理IP设置

    #!/usr/bin/env python # -*- coding:utf-8 -*-网络爬虫代理 import urllib.request import random url="htt ...

  3. Python爬虫学习笔记之爬虫基础库

    知识预览 beautifulsoup的简单使用 beautifulsoup的遍历文档树 beautifulsoup的搜索文档树 beautifulsoup的css选择器 回到顶部 beautifuls ...

  4. 【python基础学习】基础重点难点知识汇总

    python中decorator装饰器 语法示例: @decorator 什么是装饰器: 问题: 定义一个函数后 在运行时动态增加功能 又不想改动函数本身的代码 示例: # 希望对下列函数调用增加lo ...

  5. 【python系统学习16】编码基础知识

    编码 计算机是怎么传输和存储数据的? 就是把人类认识的中英文字.其他国家语言.数字甚至运算符等符号转成二进制的0.1,并进行存储和传输. 编码 人类语言:中英文字.其他国家语言.数字甚至运算符等符号 ...

  6. Python实战:Python爬虫学习教程,获取电影排行榜

    Python应用现在如火如荼,应用范围很广.因其效率高开发迅速的优势,快速进入编程语言排行榜前几名.本系列文章致力于可以全面系统的介绍Python语言开发知识和相关知识总结.希望大家能够快速入门并学习 ...

  7. Python爬虫学习之获取网页源码

    偶然的机会,在知乎上看到一个有关爬虫的话题<利用爬虫技术能做到哪些很酷很有趣很有用的事情?>,因为强烈的好奇心和觉得会写爬虫是一件高大上的事情,所以就对爬虫产生了兴趣. 关于网络爬虫的定义 ...

  8. Python爬虫学习之使用beautifulsoup爬取招聘网站信息

    菜鸟一只,也是在尝试并学习和摸索爬虫相关知识. 1.首先分析要爬取页面结构.可以看到一列搜索的结果,现在需要得到每一个链接,然后才能爬取对应页面. 关键代码思路如下: html = getHtml(& ...

  9. [Python学习] 简单网络爬虫抓取博客文章及思想介绍

            前面一直强调Python运用到网络爬虫方面很有效,这篇文章也是结合学习的Python视频知识及我研究生数据挖掘方向的知识.从而简介下Python是怎样爬去网络数据的,文章知识很easy ...

  10. Python爬虫(1):基础知识

    爬虫基础知识 一.什么是爬虫? 向网站发起请求,获取资源后分析并提取有用数据的程序. 二.爬虫的基本流程 1.发起请求 2.获取内容 3.解析内容 4.保存数据 三.Request和Response ...

随机推荐

  1. javascript编码规范[原创]

    一些命名规范书或js书命名规范章节,喜欢将命名规范跟语法混在一块例如: 1.使用“var”定义.初始化变量防止产生全局变量,多变量一块定义使用“,”(本身这种方式就很有争议). 2.结尾必加“;”防止 ...

  2. Java Float类型 减法运算时精度丢失问题

    package test1; public class Test2 { /*** @param args*/public static void main(String[] args) {   Flo ...

  3. pycharm设置及激活码

    电脑上装了python2.7和python3.6两个版本(之前用的都是python3,因为要学习机器学习和深度学习了,机器学习的有些模块还没有更新到python3,于是乎又装了python2)为了能在 ...

  4. 为已经存在的TFS团队项目配置SharePoint集成

    配置好TFS团队项目集合与SharePoint站点集的集成后,就可以在新建TFS团队项目时集成SharePoint站点,也可以为已经存在的团队项目配置SharePoint站点的集成,如下图:   Fi ...

  5. Js 事件详解

    1.事件流 1.1 事件流 描述的是在页面中接受事件的顺序 1.2 事件冒泡 由最具体的元素接收,然后逐级向上传播最不具体的元素的节点(文档) 1.3 事件捕获 最不具体的节点先接收事件,而最具体的节 ...

  6. django系列6--Ajax03 ajax参数

    ajax的参数 data: 当前ajax请求要携带的数据,是一个json的object对象,ajax方法会默认的把它编码成某种格式 (urlencoded:?a=1&b=2)发送给服务端;此外 ...

  7. BZOJ 3813--奇数国(线段树&欧拉函数&乘法逆元&状态压缩)

    3813: 奇数国 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 755  Solved: 432[Submit][Status][Discuss] ...

  8. ava Maven项目之Nexus私服搭建和版本管理应用

    目录: Nexus介绍 环境.软件准备 Nexus服务搭建 Java Maven项目版本管理应用 FAQ 1.Nexus介绍 Nexus是一个强大的Maven仓库管理器,它极大地简化了自己内部仓库的维 ...

  9. [Objective-C语言教程]基础框架(34)

    如果您参考Apple文档,应该会看到Foundation框架的详细信息,如下所示. Foundation框架定义了Objective-C类的基础层. 除了提供一组有用的原始对象类之外,它还引入了几个定 ...

  10. Linux命令行测试网速speedtest.net

    Linux命令行测试网速speedtest.net 当发现上网速度变慢时,人们通常会先首先测试自己的电脑到网络服务提供商(通常被称为"最后一公里")的网络连接速度.在可用于测试宽带 ...