aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/http/proxy_servers_and_tunneling/index.html
blob: e9318df06d032c76ed58f5b8932ec3fe8b0c92e1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
---
title: Proxy servers and tunneling
slug: Web/HTTP/Proxy_servers_and_tunneling
tags:
  - HTTP
  - HTTP Tunneling
  - NeedsTranslation
  - Proxies
  - Proxy
  - TopicStub
  - 代理
  - 隧道
translation_of: Web/HTTP/Proxy_servers_and_tunneling
---
<div>{{HTTPSidebar}}</div>

<p class="summary">当访问不同的网站时,代理服务器和HTTP管道帮助访问万维网 . 一个代理可以是用户的本地计算机,或者介于用户计算机和终端服务器之间的地方。本章节概述一些关于代理和相关配置选项的基础知识。</p>

<p>有两种代理: <strong>正向代理</strong> (如:管道、网关) 和<strong>反向代理</strong> (用于控制和保证服务器的负载均衡、认证、加密和缓存)。</p>

<h2 id="正向代理">正向代理</h2>

<p>正向代理, 也可以叫“网关” 或者仅仅为一个或多个客户端提供代理服务的“代理”。在互联网上像这样的代理不计其数。 他们存储并转发网络服务(如DNS,网页)以减少和控制大家所使用的带宽。</p>

<p>正向代理可以是匿名代理,并允许用户在浏览web或者使用其他服务时隐藏自己的IP。 <a href="https://www.torproject.org/">TOR</a> (洋葱路由), 匿名地在多个代理间路由因特网。</p>

<h2 id="反向代理">反向代理</h2>

<p>顾名思义,反向代理所做的事情与正向代理相反:正向代理代表客户端(或者发送请求的主机),而反向代理代表服务器。正向代理可以隐藏客户端的身份,而反向代理可以隐藏服务器的身份。反向代理的用处很多,例如:</p>

<ul>
 <li>负载均衡:在多个服务器之间分发负载,</li>
 <li>缓存静态内容:缓存图片等静态内容,为服务器分担压力,</li>
 <li>压缩:压缩和优化内容以加快传输的速度。</li>
</ul>

<h2 id="通过代理转发客户端消息">通过代理转发客户端消息</h2>

<p>代理可以将请求地址设置为自身的IP,这可以隐匿客户端的身份。然而,这也会导致原始请求的部分信息丢失。发起请求的客户端的IP地址可以用来调试、统计或者生成基于位置的内容。通常使用如下 HTTP 头来暴露这部分信息:</p>

<p>标准头部:</p>

<dl>
 <dt>{{HTTPHeader("Forwarded")}}</dt>
 <dd>Contains information from the client-facing side of proxy servers that is altered or lost when a proxy is involved in the path of the request.</dd>
</dl>

<p>Or the de-facto standard versions:</p>

<dl>
 <dt>{{HTTPHeader("X-Forwarded-For")}} {{non-standard_inline}}</dt>
 <dd>Identifies the originating IP addresses of a client connecting to a web server through an HTTP proxy or a load balancer.</dd>
 <dt>{{HTTPHeader("X-Forwarded-Host")}} {{non-standard_inline}}</dt>
 <dd>Identifies the original host requested that a client used to connect to your proxy or load balancer.</dd>
 <dt>{{HTTPHeader("X-Forwarded-Proto")}} {{non-standard_inline}}</dt>
 <dd>identifies the protocol (HTTP or HTTPS) that a client used to connect to your proxy or load balancer.</dd>
</dl>

<p>To provide information about the proxy itself (not about the client connecting to it), the <code>Via</code> header can be used.</p>

<dl>
 <dt>{{HTTPHeader("Via")}}</dt>
 <dd>Added by proxies, both forward and reverse proxies, and can appear in the request headers and the response headers.</dd>
</dl>

<h2 id="HTTP_tunneling">HTTP tunneling</h2>

<p>Tunneling transmits private network data and protocol information through public network by encapsulating the data. HTTP tunneling is using a protocol of higher level (HTTP) to transport a lower level protocol (TCP).</p>

<p>The HTTP protocol specifies a request method called {{HTTPMethod("CONNECT")}}. It starts two-way communications with the requested resource and can be used to open a tunnel. This is how a client behind an HTTP proxy can access websites using SSL (i.e. HTTPS, port 443). Note, however, that not all proxy servers support the <code>CONNECT</code> method or limit it to port 443 only.</p>

<p>See also the <a href="https://en.wikipedia.org/wiki/HTTP_tunnel">HTTP tunnel article on Wikipedia</a>.</p>

<h2 id="Proxy_Auto-Configuration_PAC">Proxy Auto-Configuration (PAC)</h2>

<p>A <a href="/en-US/docs/Mozilla/Projects/Necko/Proxy_Auto-Configuration_(PAC)_file">Proxy Auto-Configuration (PAC)</a> file is a <a href="/en-US/docs/Web/JavaScript">JavaScript</a> function that determines whether web browser requests (HTTP, HTTPS, and FTP) go directly to the destination or are forwarded to a web proxy server. The JavaScript function contained in the PAC file defines the function:</p>

<p id="Saving_the_Auto-Config_File_Setting_the_MIME_Type">The auto-config file should be saved to a file with a <code>.pac</code> filename extension:</p>

<pre class="syntaxbox notranslate">proxy.pac</pre>

<p>And the MIME type set to:</p>

<pre class="syntaxbox notranslate">application/x-ns-proxy-autoconfig</pre>

<p>The file consists of a function called <code>FindProxyForURL</code>. The example below will work in an environment where the internal DNS server is set up so that it can only resolve internal host names, and the goal is to use a proxy only for hosts that aren't resolvable:</p>

<pre class="brush: js notranslate">function FindProxyForURL(url, host) {
  if (isResolvable(host))
    return "DIRECT";
  else
    return "PROXY proxy.mydomain.com:8080";
}</pre>

<p>See <a href="/en-US/docs/Web/HTTP/Proxy_servers_and_tunneling/Proxy_Auto-Configuration_(PAC)_file">Proxy Auto-Configuration (PAC)</a> for more examples.</p>

<h2 id="See_also">See also</h2>

<ul>
 <li>{{HTTPMethod("CONNECT")}}</li>
 <li><a href="https://en.wikipedia.org/wiki/Proxy_server">Proxy server on Wikipedia</a></li>
</ul>