`

HTTP协议 (五) 代理

 
阅读更多

阅读目录

  1. 什么是代理服务器
  2. Fiddler就是个典型的代理
  3. 代理作用一:fanqiang
  4. 代理作用二:匿名访问
  5. 代理作用三:通过代理上网
  6. 代理作用四:通过代理缓存,加快上网速度
  7. 代理作用五:儿童过滤器
  8. IE代理设置:手动设置代理
  9. IE代理设置:使用自动配置脚本(PAC)
  10. IE代理设置:自动探测设置(WPAD)
  11. 代理认证,407状态码
  12. 使用代理服务器的安全问题
  13. 如何搭建代理服务器

 

什么是代理服务器

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

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

 

 

Fiddler就是个典型的代理

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

 

 

代理的作用一, fanqiang

很多人都喜欢用Facebook, 看youTube。但是我们在天朝,天朝有The Great of Wall(长城防火墙),屏蔽了这些好网站。  怎么办?   通过代理来跳墙,就可以访问了。

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

 

代理的作用二, 匿名访问

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

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基本认证是一样的机制, 如需了解代理认证的机制,请看[HTTP协议基本认证]

 

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

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

 

如何搭建代理服务器

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

 

分享到:
评论

相关推荐

    芯片独家销售代理协议书(合同).doc

    芯片独家销售代理协议书(合同).doc 该协议书是关于芯片独家销售代理的协议,双方签订的协议书,明确了甲方(制造商)和乙方(销售代理人)之间的权利和义务。 第一条:独家销售代理权 甲方同意将其生产的芯片...

    年股权委托代理合同协议书范本.pdf

    ### 年股权委托代理合同协议书范本解析 #### 一、概述 本文档是一份标准的股权委托代理合同协议书范本,旨在规范甲方(委托方)与乙方(受委托方)之间的委托代理关系。甲方是某上市公司的股东,持有一定比例的股权...

    HTTP协议分析报告

    #### 五、HTTP协议的无状态性 - **无状态性**: 服务器无法通过HTTP协议记录用户的登录信息,这意味着服务器不能记住关于用户的信息。 - **解决方案**: 使用Cookie机制来保存信息。 #### 六、Wireshark抓包实验 - ...

    销售代理协议样式五精选.doc

    以下是对《销售代理协议样式五精选》主要内容的详细解读: 1. **代理资格确认**:甲方在选择乙方作为销售代理时,会考虑乙方的运营条件,包括独立的运营场地、完善的销售网络、充足的资金和良好的资信。此外,乙方...

    http协议详细介绍

    #### 五、HTTP消息结构 HTTP消息由客户端发送给服务器的请求(Request)和服务器返回给客户端的响应(Response)组成。 - **Request消息**通常包括以下部分: - **Request line**(请求行):包含了请求的方法...

    HTTP代理穿透方法

    4. **兼容性考虑**:不同的代理服务器和支持的协议可能有所不同,需要根据实际情况选择合适的代理服务器和技术方案。 #### 五、总结 HTTP代理穿透技术为无法直接访问目标服务器的情况提供了解决方案。通过对`HTTP ...

    夏令营代理商合作协议范本新.doc

    【夏令营代理商合作协议范本】是一份详细规定了夏令营组织者(甲方)与代理机构(乙方)之间权利和义务的法律文件。该协议主要用于规范双方在夏令营招生过程中的合作行为,确保活动的顺利进行和双方的利益。 **一、...

    招标代理协议书

    ### 招标代理协议书相关知识点解析 #### 一、背景与定义 **招标代理协议书**是一种法律文书,用于规范委托方(建设单位)与受托方(招标代理机构)之间的权利与义务关系,确保招标过程的公正、公平进行。此协议书...

    最新白酒代理广告网络广告代理协议书示范文本.docx

    9. **委托代理期限**:协议期限为五年,自生效日起计算,规定了合作的长期性。 10. **违约责任**:违约方需承担相应违约金,并可能赔偿超出违约金的损失,确保协议的严肃性和约束力。 11. **争议解决**:双方若...

    HTTP协议原理+实践 Web开发工程师必学

    HTTP(Hypertext Transfer Protocol)超文本传输协议是互联网上应用最为广泛的一种网络协议,它是Web浏览器和服务器之间通信的基础。理解HTTP协议的原理对于Web开发工程师来说至关重要,因为这直接影响到网页的加载...

    销售代理协议书.rar

    销售代理协议书是商业活动中常见的法律文件,尤其在教育领域,可能会涉及到教材、教辅资料等产品的销售代理。本文将详细解析销售代理协议书的主要内容、关键条款以及它在教育行业中的应用。 销售代理协议书是制造商...

    (中文完整版) HTTP协议1.1

    - **跨协议通信**: HTTP也可用于用户代理之间以及代理/网关到其他网络系统的通信,这些网络系统可能支持SMTP、NNTP、FTP、Gopher和WAIS等协议。 通过以上内容可以看出,HTTP/1.1协议在HTTP/1.0的基础上进行了大量的...

    HTTP协议内容简介

    #### 五、HTTP状态码 **HTTP状态码**用于表示服务器对请求的处理结果,常见的状态码包括: - **200 OK**:请求成功。 - **400 Bad Request**:客户端请求有语法错误。 - **401 Unauthorized**:未授权。 - **403 ...

    反向传值(协议代理)

    五、父控制器实现协议 父控制器实现协议并设置子控制器的代理: ```objc @interface ParentViewController : UIViewController @end @implementation ParentViewController - (void)viewDidLoad { ...

    HTTP协议详解

    HTTP(超文本传输协议)是互联网上应用最广泛的一种网络协议,用于在Web浏览器和服务器之间传输数据。它是无状态的,意味着每个请求都是独立的,服务器不会记住之前请求的状态。HTTP协议通过扩展其请求方法、错误...

    协议书代理商合作协议书资料.pdf

    【标题】: 代理商合作协议书 【描述】: 本文档是关于代理商合作协议书的详细内容,涵盖了甲乙双方在代理销售产品过程中的权益、责任和义务。 【知识点详解】 一、合作内容与地域限制 - 合作内容:甲乙双方基于...

    代理程序通信协议1

    每个数据包由五部分组成:协议头(PV)、序列号、请求方、响应方和命令字,以及数据内容。协议头的值0x00代表请求,0x01代表响应。序列号保证通信的唯一性,请求方和响应方通过ChannelId来识别,命令字定义了具体的...

    HTTP协议详解.pdf

    - CONNECT:用于HTTP/2或HTTPS的代理隧道。 - TRACE:回显服务器收到的请求,用于调试。 四、HTTP响应状态码 状态码由三位数字组成,分为五类: - 1xx(信息性状态码):表示临时响应,告知客户端请求已接收,继续...

    http1.1协议中文版

    ### HTTP/1.1协议详解 #### 一、概述 HTTP/1.1协议作为超文本传输协议(HyperText Transfer Protocol)的一种版本,是互联网上应用最广泛的协议之一。它定义了客户端与服务器之间如何传输数据的标准。相较于早期...

Global site tag (gtag.js) - Google Analytics