注意: IP代理精灵仅提供国内ip网络节点,不提供境外网络节点,不能用于任何非法用途或访问境外封闭网站,不能跨境联网,只能用于合法的国内网络加速。

请登录 注册

首页 > 新闻资讯 > 让代理服务器支持HTTPS很难吗?

让代理服务器支持HTTPS很难吗?

来源:IP代理精灵 作者:admin 时间:2019-05-29 11:43:36

我们开展稳定高匿名HTTP代理业务以来,我听到客户咨询最多的问题之一就是“你们的代理支持HTTPS协议吗?”。我觉得很多人对HTTPS代理存在理解上的误区,所以我写了这篇文章。目的就是想说明“实现支持HTTPS的代理一点都不难!”。


说到HTTPS代理很多人瞬间就会联想到HTTPS的各种证书和各种加密,觉得很高端很复杂的样子。其实不然,代理服务器不需要配置证书、也不需要处理任何加密。因为HTTPS代理是通过Web隧道(Web tunnel)工作的。


Web隧道允许用户通过HTTP连接发送非HTTP流量(例如FTP,Telnet,SMTP),这就使得那些使用非HTTP协议的应用程序可以通过HTTP代理工作了。你现在应该就明白了为什么QQ可用设置使用HTTP代理工作。Web隧道这么强大,但它并不复杂。


Web隧道是用HTTP协议的CONNECT方法建立起来的。CONNECT方法不是HTTP/1.1核心规范的一部分,但确是一种得到广泛应用的扩展。客户端通过CONNECT方法请求代理服务器创建一条到达任意目的服务器和端口的TCP链接,代理服务器仅对客户端和服务器之间的后续数据进行盲转发(只是转发,不关心、也不懂发送的内容是什么)。


建立Web隧道的详细步骤如下:


1)客户端通过HTTP协议发送一条CONNECT方法的请求给代理服务器,告知代理服务器需要连接的主机和端口。


例如:


CONNECT www.alipay.com:443 HTTP/1.1


User-agent: Mozilla/5.0


在本例中客户端通过CONNECT方法请求代理服务器打开一条到www.alipay.com主机443端口的TCP链接。


2)代理服务器一旦建立了和目标主机(上例中的www.alipay.com:443)TCP连接,就会回送一条HTTP 200 Connection Established应答给客户端。


例如:


HTTP/1.1 200 Connection Established


Poryx-Agent: Squid/3.2


3)此时隧道就建立起来了。客户端通过该HTTP隧道发送的所有数据都会被代理服务器(通过之前建立起来的与目标主机的TCP连接)原封不动的转发给目标服务器。目标服务器发送的所有数据也会被代理服务器原封不动的转发给客户端。注意:是原封不动的转发,代理服务器并不需要知道内容的含义,也不会尝试去对内容进行解析。

让代理服务器支持HTTPS很难吗?

PS:上面这张插图是我引用《HTTP权威指南》一书的,做了修改。


这下你应该明白了Web隧道的工作原理。所以对代理服务器来说只要其支持Web隧道就支持HTTPS协议(和其它非HTTP协议),与证书、加密没有任何直接的关系。从上面的过程可以看出,实现Web隧道并不难,只要代理服务器能够正确处理CONNECT请求,然后对数据进行盲转发即可。从难度上看这比标准的HTTP协议代理还要简单(标准HTTP协议代理需要对客户端和服务端双方的HTTP报文先进行解析,修改后再进行转发)。


现在应用最广泛的HTTP代理软件非Squid莫属,Squid默认就是支持Web隧道的,详见Squid的文档:http://wiki.squid-cache.org/Features/HTTPS。因此Squid支持HTTPS也是天生的,无需做额外设置。我们的代理服务器软件使用的也是Squid,所以100%是支持HTTPS的。


顺便提一下,Squid默认只允许建立到目标端口为443(HTTPS的默认端口)的Web隧道。但我们可以通过设置SSL_Ports参数,使其允许更多的端口。一个我实际遇到的情况:访问一个端口为非443的HTTPS网站(9061), Squid会总是返回“urlopen error Tunnel connection failed: 403 Forbidden”的错误,在SSL_Ports中添加9061端口后就工作了。关于SSL_Ports的更多解释可以参考Squid的文档:http://wiki.squid-cache.org/SquidFaq/SecurityPitfalls#The_Safe_Ports_and_SSL_Ports_ACL


最后附上我用Wireshark抓取火狐浏览器通过HTTPS代理和支付宝的交互过程的报文,及部分报文片段:

1559101557245930.jpg

让代理服务器支持HTTPS很难吗?

最新资讯

推荐阅读

  1. 03

    2021-06

    如何使用代理服务器

    如何使用代理服务器?知道了《什么是代理服务器》,也知道了《代理服务器的工作原理是什么》,还知道了《为什么要使用代理服务器》,那么,怎么使用代理服务器呢?

  2. 26

    2019-05

    云南代理IP哪里找?

    现在的代理IP行业出现一个不成文的怪圈现象,热门地区家家都有,冷门区域有钱也难求,好比云南省,面积39万平方千米,总人口5千万,在全国各省级行政区面积和人数中都是名列前茅的,但

  3. 24

    2019-04

    怎样使用代理IP进行高效的爬虫工作

    说起爬虫,很多人第一时间想到的就是Python,Python作为一门入门极易并容易上瘾的语言,已经成为很多人的标配语言。Python与其它语言(比如Java或者C、C#)相比有比较大的区别,其中最大的特

  4. 22

    2019-05

    动态拨号VPS换IP有什么作用

    大家应该都怕碰上类似的情况:网店虚假单子过多导致被封的可能、网站发布过多信息而造成的IP被封的危险、上网速度跟不上而抢不到自己打算购买的商品、这些难题ip代理精灵可以帮你搞定

  5. 13

    2019-06

    http代理ip怎样保障上网安全

    与直接连接到Internet相比,使用http代理IP上网能更好保护上网用户的IP地址,从而保障网络安全。如果我们需要注册多个不同IP地址的账号,如QQ账号、论坛账号、供刷机用的其他不同账号,或者

  6. 27

    2020-11

    使用代理IP后上网速度更慢的原因

    使用代理IP后上网速度更慢的原因!很多使用过代理IP的人都发现了这样一个问题,就是通过使用代理IP后上网的网速,会比没有使用代理IP上网的网速更慢一些,这是什么原因呢,我们一起来讨论