代理服务器

Web代理(proxy)服务器是网络的中间实体。 代理位于Web客户端和Web服务器之间,扮演“中间人”的角色。

HTTP的代理服务器即是Web服务器又是Web客户端。

Fiddler就是个典型的代理

Fiddler 是以代理web服务器的形式工作的,它使用代理地址:127.0.0.1, 端口:8888. 当Fiddler退出的时候它会自动注销代理,这样就不会影响别的程序。

代理的作用

自己去寻找代理服务器很麻烦, 一般都是用FQ软件来自动发现代理服务器的。

代理的作用二 匿名访问

经常听新闻,说”某某某“在网络上发布帖子,被跨省追缉了。   假如他使用匿名的代理服务器,就不容易暴露自己的身份了。

http代理服务器的匿名性是指: HTTP代理服务器通过删除HTTP报文中的身份特性(比如客户端的IP地址, 或cookie,或URI的会话ID), 从而对远端服务器隐藏原始用户的IP地址以及其他细节。 同时HTTP代理服务器上也不会记录原始用户访问记录的log(否则也会被查到)。

代理的作用三 通过代理上网

比如局域网不能上网, 只能通过局域网内的一台代理服务器上网。

代理的作用四 通过代理缓存,加快上网速度

大部分代理服务器都具有缓存的功能,就好像一个大的cache, 它有很大的存储空间,它不断将新取得数据存储到它本地的存储器上, 如果浏览器所请求的数据在它本机的存储器上已经存在而且是最新的,那么它就不重新从Web服务器取数据,而直接将存储器上的数据传给用户的浏览器,这样就能显著提高浏览速度。

代理的作用五 儿童过滤器

很多教育机构, 会利用过滤器代理来阻止学生访问成人内容。

IE代理设置:手动设置代理

IE浏览器可以手动设置代理, 很简单,指定一个IP地址和端口就可以了。 如下图。

工具 -> Internet选项 -> 连接 -> 局域网设置 (快捷键)

假如代理服务器的IP地址改变了,或者端口号改变了。 难道要几百个客户端的浏览器去修改浏览器设置? Impossable  这太难维护了。

下面还有一种更高级点的方法。

IE代理设置:使用自动配置脚本(PAC)

手动配置代理很简单,但是不灵活。 只能指定一个代理服务器,而且不支持故障转移。

在大公司里一般都使用PAC文件来配置。只需要指定PAC文件的URL就可以了, 如图:

PAC(Proxy Auto Config)文件是一个小型的JavaScript程序的文本文件,后缀为.dat。

当浏览器访问网络的时候,会根据PAC文件中的JavaScript函数来选择恰当的代理服务器。

sample_pac.dat文件的内容

function FindProxyForURL(url, host) {if (url.substring(0, 5) == "http:") {// 应该使用指定的代理return "PROXY proxy:80";}else if (url.substring(0, 4) == "ftp:") {return "PROXY fproxy:80";}else if (url.substring(0, 7) == "gopher:") {return "PROXY gproxy";}else if (url.substring(0, 6) == "https:") {return "PROXY secproxy:8080";}else {// 直连,不经过任何代理return "DIRECT";}
}

IE代理设置:自动探测设置(WPAD)

浏览器只要选中“自动检测设置”, 就可以使用WPAD协议, WPAD会自动找到PAC文件的URL。  WPAD会使用一系列的资源发现技术(DHCP,DNS等)去寻找PAC文件。

代理认证和407状态码

代理服务器也可以需要权限认证, HTTP定义了一种名为代理认证(Proxy authentication)的机制。 这种机制可以阻止对内容的请求。

当浏览器访问需要认证的代理时, 代理服务器会返回407 Authorization Required,告诉浏览器输入用户名和密码。代理认证跟HTTP基本认证是一样的机制

使用代理服务器的安全问题

代理服务器和抓包工具(比如Fiddler)都能看到http request中的数据。 如果我们发送的request中有敏感数据,比如用户名,密码,信用卡号码。这些信息都会被代理服务器看到。所以非常危险。 所以我们一般都是用HTTPS来加密Http request.  这样代理服务器就看不到里面的数据了。

如何搭建代理服务器

可以使用CCproxy, 和Squid 来搭建代理服务器。

转载于:https://www.cnblogs.com/tiantianle/p/5335321.html

HTTP协议5之代理--转相关推荐

  1. 使用Nginx为TCP/WebSocket协议做反向代理和几个易踩的坑

    通常,我们使用Nginx为后端WEB服务做反向代理或负载均衡,但如果我们的后端服务,并不是HTTP/HTTPS协议,而是TCP协议或WebSocket协议呢 最近遇到一个需求,我们的HTTPS以及MQ ...

  2. protocol(协议)、delegate(代理)

    protocol(协议).delegate(代理) 一.protocol(协议) 1.概念:把多个类中的某些共同属性.方法抽象到一个类中,但这些属性.方法在不同的类中有不同的实现,相当于Java中的接 ...

  3. HTTP权威协议笔记-6.代理

    6.1 Web的中间实体 Http的代理服务器即是客户端的服务器又是服务器的客户端. 它介于服务器与客户端之间,当客户端发送请求报文经过它时,它会像服务器一样正确的处理请求和返回响应,同时,代理服务器 ...

  4. 基于TCP协议的游戏代理接口测试工具<一>:设计初衷与工具构想

    设计初衷 大势所逼 众所周知,区别于HTTP之类的协议,由于tcp协议包体通信的高度定制化导致业内基本没有通用的接口工具用于游测人员进行日常使用,大部分的情况是基于这种状态下只能进行测试工具定制.在日 ...

  5. nginx实现对websocket加密协议wss协议的反向代理以及websocket整合springboot入门(踩坑)

    出发点 最近公司需要有一个推送前端消息的需求 首选websocket进行推送,也做过客服系统接触过,最近看了一点websocket的相关内容记录总结一下. 什么是websocket websocket ...

  6. Objective-C学习之Protocal协议,设置代理

    protocal在三种情况中需要用到: 需要声明别的类期望完成的方法时 在隐藏自身类的情况下声明该类对象的接口时 在某些没有继承关系的类之间获取其之间的相似性,即两个类之间没有继承关系,但是都需要实现 ...

  7. OC基础 代理和协议

    OC基础 代理和协议 1.协议 (1)oc语言中得协议:一组方法列表,不需要我们自己实现,由遵守协议的类来实现协议所定制的方法. (2)协议的使用步骤:制定协议-->遵守协议-->实现协议 ...

  8. swift 用协议实现代理传值功能

    2019独角兽企业重金招聘Python工程师标准>>> swift 用协议实现代理传值功能 原文  http://blog.csdn.net/whzhaochao/article/d ...

  9. 简单的协议应用-代理模式

    协议(protocol): <> 遵守某个协议,只要遵守了这个协议,相当于拥有协议里面的所有方法声明 声明一系列方法 编译器不强求实现协议里所有的方法 分类和协议都只能声明方法,不能声明成 ...

  10. 设置git协议clone代理

    0x0 最近在clone yaffs2仓库时发现clone的异常缓慢,就算开了代理也是,搜索一番发现网上大多都是将设置http.https.ssh协议的代理,对于git协定的代理讲的很少,下面分享下如 ...

最新文章

  1. spring boot系列03--spring security (基于数据库)登录和权限控制(下)
  2. springboot入门_打包部署
  3. fastjson反序列化漏洞研究(下)
  4. JIRA6.3.6中设置用户的解决问题和关闭问题权限
  5. oracle em 界面乱码,oracle em 按钮乱码解决办法及em网页变成英文
  6. switch..case使用
  7. lldb 调试php,linux系统下如何在vscode中调试C++代码
  8. 2017 《Java技术预备作业 》1501 乔 赫
  9. docker Redis集群
  10. 暂不升级iOS 14.2:多款iPhone续航崩溃
  11. dhcp获取i需要trunk_Cisco三层交换上给不同Vlan配置不同的DHCP
  12. INSTALLSHIELD11.5中打包水晶报表的问题,ScriptProject与ScriiptMSIProject差异引起的错误!...
  13. centos6.2系统下安装配置FastDFS步骤
  14. 【BZOJ4378】[POI2015]Logistyka 树状数组
  15. SAP那些事-理论篇-5-SAP玩你还是你玩SAP
  16. 程序员自学编程的6种方法,高效学习
  17. 初入职场着装宝典(BOY)
  18. web前端开发技术实验与实践(第三版)储久良编著 项目6 文本与段落标记的应用
  19. M2增速8%处于历史地位——解读10月货币数据
  20. Xilinx Xio控制sdr sdram

热门文章

  1. SQL Leetcode练习题
  2. 脚踏实地、仰望星空的贵系学子们
  3. 德鲁克谈《自我管理》笔记摘要
  4. edge bing搜索响应缓慢
  5. 相似度度量的不同方法
  6. 高中数学竞赛与自主招生内部练习试题
  7. matlab rand函数的用法,matlab中rand函数的用法
  8. 驾驶本到期换新,要想照片拍的好看,办理不耽误时间请按照以下步骤进行
  9. 万字干货!《增长黑客》背后的逻辑
  10. 【论文笔记】 Leverage Lexical Knowledge Base for Chinese NER via Collborative Graph Network