本文转自:
http://www.cnblogs.com/TankXiao/archive/2012/12/12/2794160.html
这次介绍代理服务器, 代理服务器是HTTP协议中一个重要的组件, 发挥着重要的作用。 本文介绍一些HTTP代理服务器的概念和工作原理
什么是代理服务器
Web代理(proxy)服务器是网络的中间实体。 代理位于Web客户端和Web服务器之间,扮演“中间人”的角色。
HTTP的代理服务器即是Web服务器又是Web客户端。
Fiddler就是个典型的代理
Fiddler 是以代理web服务器的形式工作的,它使用代理地址:127.0.0.1, 端口:8888. 当Fiddler退出的时候它会自动注销代理,这样就不会影响别的程序。
代理的作用一, 翻-墙
很多人都喜欢用Facebook, 看youTube。但是我们在天朝,天朝有The Great of Wall(长城防火墙),屏蔽了这些好网站。 怎么办? 通过代理来跳墙,就可以访问了。
自己去寻找代理服务器很麻烦, 一般都是用翻-墙软件来自动发现代理服务器的。
代理的作用二, 匿名访问
经常听新闻,说”某某某“在网络上发布帖子,被跨省追缉了。 假如他使用匿名的代理服务器,就不容易暴露自己的身份了。
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 该协议书是关于芯片独家销售代理的协议,双方签订的协议书,明确了甲方(制造商)和乙方(销售代理人)之间的权利和义务。 第一条:独家销售代理权 甲方同意将其生产的芯片...
代理合同:个人委托人事代理协议书 本资源是关于代理合同的个人委托人事代理协议书,涵盖了人事代理服务的各个方面,包括人事行政关系、档案管理、社会保险、计划生育等。该协议书明确了甲方(受托方)和乙方(委托...
《独家代理销售协议》是商业活动中常见的法律文件,主要用于规定供应商(甲方)与代理商(乙方)之间的权利和义务。以下是对这份合同主要内容的详细解读: 一、授权与区域保护 甲方授权乙方为特定地区(__________...
2. **HTTP协议**:HTTP(HyperText Transfer Protocol)是一种用于传输超文本的应用层协议,它是Web通信的基础。 3. **连接方法**:HTTP代理穿透中常用的方法包括`HTTP CONNECT`、`HTTP GET/POST`等。 #### 三、...
#### 五、HTTP协议的无状态性 - **无状态性**: 服务器无法通过HTTP协议记录用户的登录信息,这意味着服务器不能记住关于用户的信息。 - **解决方案**: 使用Cookie机制来保存信息。 #### 六、Wireshark抓包实验 - ...
### 年股权委托代理合同协议书范本解析 #### 一、概述 本文档是一份标准的股权委托代理合同协议书范本,旨在规范甲方(委托方)与乙方(受委托方)之间的委托代理关系。甲方是某上市公司的股东,持有一定比例的股权...
以下是对《销售代理协议样式五精选》主要内容的详细解读: 1. **代理资格确认**:甲方在选择乙方作为销售代理时,会考虑乙方的运营条件,包括独立的运营场地、完善的销售网络、充足的资金和良好的资信。此外,乙方...
- **port#**:HTTP服务器的默认端口是80,如果使用非默认端口,则需明确指定,如`http://www.example.com:8080`。 - **path**:访问资源的具体路径。 - **query-string**:附加的查询字符串,包含请求参数。 - **...
### 出租香港住宅物业用的地产代理协议关键知识点解析 #### 一、协议概述 在出租香港住宅物业的过程中,业主通常会与地产代理签订一份详细的代理协议,以明确双方的权利与义务。此类协议旨在规范代理行为,保障交易...
- **定义**: 地产代理协议是指地产代理与其客户(即租客)之间签订的一份正式书面合同,用于规范双方之间的权利与义务。 - **目的**: 通过明确双方的责任和义务,确保交易过程中的透明度和公正性,保护双方利益不受...
9. **委托代理期限**:协议期限为五年,自生效日起计算,规定了合作的长期性。 10. **违约责任**:违约方需承担相应违约金,并可能赔偿超出违约金的损失,确保协议的严肃性和约束力。 11. **争议解决**:双方若...
### 招标代理协议书相关知识点解析 #### 一、背景与定义 **招标代理协议书**是一种法律文书,用于规范委托方(建设单位)与受托方(招标代理机构)之间的权利与义务关系,确保招标过程的公正、公平进行。此协议书...
2. **HTTP协议的工作方式**:HTTP是一种基于请求/响应模式的协议。客户端向服务器发送请求,请求包括URL、协议版本号等信息。服务器接收到请求后,返回包含状态码、服务器信息等内容的响应。整个过程类似于电话订货...
- **跨协议通信**: HTTP也可用于用户代理之间以及代理/网关到其他网络系统的通信,这些网络系统可能支持SMTP、NNTP、FTP、Gopher和WAIS等协议。 通过以上内容可以看出,HTTP/1.1协议在HTTP/1.0的基础上进行了大量的...
- Persistent Connections(持久连接):HTTP/1.1默认开启,允许复用TCP连接,减少连接建立和关闭的开销。 - Pipelining(管道化):在同一持久连接上,客户端可以同时发送多个请求,无需等待每个请求的响应。 - ...
- **无状态性**:HTTP 是无状态的,即服务器不保存关于客户端的任何信息,这意味着如果后续处理需要前面的信息,则必须重新发送这些信息。 - **支持多种模式**:支持B/S(浏览器/服务器)和C/S(客户端/服务器)...
【服装代理商经营加盟协议书】 本协议书是甲方——某市服装有限公司与乙方之间关于授权经营"少年装"系列产品的法律文件,旨在确保品牌信誉、消费者权益和双方互利共赢的合作关系。协议严格遵循《经济合同法》和相关...
HTTP(Hypertext Transfer Protocol)超文本传输协议是互联网上应用最为广泛的一种网络协议,它是Web浏览器和服务器之间通信的基础。理解HTTP协议的原理对于Web开发工程师来说至关重要,因为这直接影响到网页的加载...
### 制造商与代理商经销协议关键知识点解析 #### 一、协议背景与定义 - **背景**: 本文档描述了一份制造商与代理商之间的经销协议,旨在明确双方在合作过程中的权利与义务。此协议适用于制造商希望拓展其产品市场时...