我们在做爬虫的过程中经常会遇到这样的情况,最初爬虫正常运行,正常抓取数据,一切看起来都是那么美好,然而一杯茶的功夫可能就会出现错误,比如403 Forbidden,这时候打开网页一看,可能会看到“您的IP访问频率太高”这样的提示。出现这种现象的原因是网站采取了一些反爬虫措施。比如,服务器会检测某个IP在单位时间内的请求次数,如果超过了这个阈值,就会直接拒绝服务,返回一些错误信息,这种情况可以称为封IP。
既然服务器检测的是某个IP单位时间的请求次数,那么借助某种方式来伪装我们的IP,让服务器识别不出是由我们本机发起的请求,不就可以成功防止封IP了吗?
一种有效的方式就是使用代理,后面会详细说明代理的用法。在这之前,需要先了解下代理的基本原理,它是怎样实现IP伪装的呢?
1. 基本原理
代理实际上指的就是代理服务器,英文叫作proxy server,它的功能是代理网络用户去取得网络信息。形象地说,它是网络信息的中转站。在我们正常请求一个网站时,是发送了请求给Web服务器,Web服务器把响应传回给我们。如果设置了代理服务器,实际上就是在本机和服务器之间搭建了一个桥,此时本机不是直接向Web服务器发起请求,而是向代理服务器发出请求,请求会发送给代理服务器,然后由代理服务器再发送给Web服务器,接着由代理服务器再把Web服务器返回的响应转发给本机。这样我们同样可以正常访问网页,但这个过程中Web服务器识别出的真实IP就不再是我们本机的IP了,就成功实现了IP伪装,这就是代理的基本原理。
2. 代理的作用
那么,代理有什么作用呢?我们可以简单列举如下。
- 突破自身IP访问限制,访问一些平时不能访问的站点。
- 访问一些单位或团体内部资源:比如使用教育网内地址段免费代理服务器,就可以用于对教育网开放的各类FTP下载上传,以及各类资料查询共享等服务。
- 提高访问速度:通常代理服务器都设置一个较大的硬盘缓冲区,当有外界的信息通过时,同时也将其保存到缓冲区中,当其他用户再访问相同的信息时,则直接由缓冲区中取出信息,传给用户,以提高访问速度。
- 隐藏真实IP:上网者也可以通过这种方法隐藏自己的IP,免受攻击。对于爬虫来说,我们用代理就是为了隐藏自身IP,防止自身的IP被封锁。
3. 爬虫代理
对于爬虫来说,由于爬虫爬取速度过快,在爬取过程中可能遇到同一个IP访问过于频繁的问题,此时网站就会让我们输入验证码登录或者直接封锁IP,这样会给爬取带来极大的不便。
使用代理隐藏真实的IP,让服务器误以为是代理服务器在请求自己。这样在爬取过程中通过不断更换代理,就不会被封锁,可以达到很好的爬取效果。
4. 代理分类
代理分类时,既可以根据协议区分,也可以根据其匿名程度区分。
(1) 根据协议
根据代理的协议,代理可以分为如下类别。
- FTP代理服务器:主要用于访问FTP服务器,一般有上传、下载以及缓存功能,端口一般为21、2121等。
- HTTP代理服务器:主要用于访问网页,一般有内容过滤和缓存功能,端口一般为80、8080、3128等。
- SSL/TLS代理:主要用于访问加密网站,一般有SSL或TLS加密功能(最高支持128位加密强度),端口一般为443。
- RTSP代理:主要用于访问Real流媒体服务器,一般有缓存功能,端口一般为554。
- Telnet代理:主要用于telnet远程控制(黑客入侵计算机时常用于隐藏身份),端口一般为23。
- POP3/SMTP代理:主要用于POP3/SMTP方式收发邮件,一般有缓存功能,端口一般为110/25。
- SOCKS代理:只是单纯传递数据包,不关心具体协议和用法,所以速度快很多,一般有缓存功能,端口一般为1080。SOCKS代理协议又分为SOCKS4和SOCKS5,前者只支持TCP,而后者支持TCP和UDP,还支持各种身份验证机制、服务器端域名解析等。简单来说,SOCK4能做到的SOCKS5都可以做到,但SOCKS5能做到的SOCK4不一定能做到。
(2) 根据匿名程度
根据代理的匿名程度,代理可以分为如下类别。
- 高度匿名代理:会将数据包原封不动地转发,在服务端看来就好像真的是一个普通客户端在访问,而记录的IP是代理服务器的IP。
-
普通匿名代理:会在数据包上做一些改动,服务端上有可能发现这是个代理服务器,也有一定几率追查到客户端的真实IP。代理服务器通常会加入的HTTP头有
HTTP_VIA
和HTTP_X_FORWARDED_FOR
。 - 透明代理:不但改动了数据包,还会告诉服务器客户端的真实IP。这种代理除了能用缓存技术提高浏览速度,能用内容过滤提高安全性之外,并无其他显著作用,最常见的例子是内网中的硬件防火墙。
- 间谍代理:指组织或个人创建的用于记录用户传输的数据,然后进行研究、监控等目的的代理服务器。
5. 常见代理设置
- 使用网上的免费代理:最好使用高匿代理,另外可用的代理不多,需要在使用前筛选一下可用代理,也可以进一步维护一个代理池。
- 使用付费代理服务:互联网上存在许多代理商,可以付费使用,质量比免费代理好很多。
- ADSL拨号:拨一次号换一次IP,稳定性高,也是一种比较有效的解决方案。
相关推荐
实现这些动画效果需要对Core Animation和UIKit有深入的理解,包括但不限于图层(Layer)的概念、动画的基本原理以及如何结合使用各种动画API。同时,良好的代码组织和性能优化也是必不可少的,例如,合理使用代理、...
这可能是为了教学或毕业设计研究而准备的,适合初学者理解iOS应用的基本架构和视图控制器的工作原理。 【描述分析】 描述提到这是"前两年的IOS应用源码",暗示这可能是基于较早版本的iOS SDK,可能使用的是Swift或...
同时,这也是一篇论文的好素材,可以深入分析加载器的设计原理、性能优化和用户体验方面的考虑。 【压缩包子文件的文件名称】:“加载器(当下载或加载缓存时候用的进度条)” 这个文件名暗示了源码中可能包含一个...
通过研究这个源码,初学者能够掌握iOS开发的基本流程,了解图表绘制的原理和实践,为以后更复杂的项目打下基础。同时,对于进行毕业设计的学生来说,这是一个很好的起点,可以帮助他们理解和应用图表展示技术,以...
4. **自定义控件**:通过创建自定义的radio按钮控件,学习自定义视图的基本原理,包括绘制视图、添加交互性等。 5. **协议与代理**:如果radio选项之间有联动效果,可能会涉及到协议和代理的设计模式,以实现不同...
3. **使用Appearance代理**:利用UIAppearance协议可以在全局范围内设置Tab Bar的样式,适用于整个应用的统一风格。 ```swift if #available(iOS 13.0, *) { UINavigationBar.appearance().titleTextAttributes =...
iOS开发的很多基础原理和技术并没有随着时间的推移而改变,因此,即使是较旧的代码,也能帮助初学者理解基本的编程概念和iOS框架的使用。通过此源码,学生可以深入理解如何将Swift(可能是当时的主流语言)或者...
在iOS开发领域,源码是理解应用程序工作原理和学习新技能的重要资源。"IOS应用源码Demo-自动滚动demo-毕设学习.zip"这个压缩包包含了一个特定的iOS应用示例,专注于自动滚动功能,这对于iOS开发者,尤其是正在进行...
通过学习Scrapy,可以理解网络爬虫的工作原理,掌握数据抓取的基本方法,同时锻炼Python编程和Web解析技能。 压缩包中的"说明.htm"可能是Scrapy的使用指南或快速入门教程,它将指导初学者如何安装Scrapy,创建第一...
"IOS源码"意味着我们可以直接查看和分析代码,学习iOS应用的内部工作原理。"毕业设计"表明这是针对学术项目或者个人项目的,可能包含了完整的应用生命周期,从需求分析到实现和测试。"论文"可能暗示源码中包含了一些...
在本例中,提供源码意味着用户可以查看和修改博客系统的内部工作原理,这对于学习编程、理解Web开发流程、进行二次开发或定制化改造非常有帮助。 3. **毕业设计论文**:这表明启明星个人小博客可能是某位学生的毕业...
首先,要理解Flask Login的基本工作原理。Flask Login的核心概念包括User类(代表用户)、login_manager(管理用户登录状态)以及一系列的装饰器函数,如@login_required(限制访问权限)。User类需要继承自flask_...
1. `UIPageViewController`的基本用法,包括如何设置其数据源和代理。 2. 如何创建自定义的`UIViewController`子类以展示不同的页面内容。 3. 实现`UIPageViewControllerDataSource`的方法,如`pageViewController(_...
这个项目显然专为毕业设计学习而准备,帮助学生了解iOS应用开发的基本流程,掌握Objective-C或Swift编程语言,以及iOS应用的架构和设计模式。 【描述】中提到的“前两年”的源码,暗示了这是一个相对较早的项目,...
【标题】"IOS应用源码Demo-从上往下拉动态加载-毕设学习.zip...通过这个项目,学习者不仅可以掌握iOS应用的基本开发技能,还能了解如何处理用户交互、数据管理、性能优化等多个重要领域,对于提升iOS开发能力大有裨益。
首先,我们需要了解单点登录(SSO)的基本原理。SSO允许用户通过一次身份验证,就能访问所有相互信任的应用系统,而无需在每个应用中分别登录。这对于大型企业或组织来说尤其有用,因为它简化了用户管理,减少了密码...
抽屉式侧边栏导航的实现原理: 1. 使用UIViewController的 containment 功能,将主视图和侧边栏视图都添加到同一个容器中。 2. 通过手势识别或者按钮点击事件来触发侧边栏的滑出和隐藏。 3. 使用UIView的动画API(如...
在iOS开发领域,源码学习是提升技能、理解应用程序工作原理的重要途径。本资源"图书管理系统"是一个专为毕业设计学习者准备的项目,它涵盖了iOS应用开发的基本要素,对于学习iOS编程、进行毕业设计或撰写相关论文...