代理ip

>

换ip软件

>

http代理

>

ip代理

您的位置:首页 > 新闻资讯 > 文章内容
代理服务器支持HTTPS难吗
来源:网连代理 作者:admin 时间:2019-09-21 15:27:58

  代理服务器支持HTTPS难吗?我们开展稳定高匿名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代理和支付宝的交互过程的报文,及部分报文片段:


代理服务器支持HTTPS难吗

相关文章内容简介
推荐阅读
  • 08 2020-01
    爬虫代理使用IP更安全吗

    我们知道,当我们上网时,我们的真实IP可能会被泄露,当被别有用心的人获取到时则可能会对我们造成一些伤害。而如果使用了代理IP​上网后,则完美的隐藏了我们的本机真实IP,多加了一份

  • 29 2020-06
  • 25 2020-02
    哪里有高质量的代理ip

    有时有些用户可能会碰到一些需要换ip的,尤其是访问比较频繁的时候,那么大家在哪里可以找到动态代理ip来更换ip地址呢?

  • 20 2020-01
    使用代理IP能帮我们做什么

    使用代理IP能帮我们做什么?遇到过很多想要购买代理IP的朋友,他们这样问我,你家的代理IP可以帮我注册账号吗?你家的代理IP​能帮我发邮件吗?你家的代理IP能帮我发广告推广产品吗?你

  • 16 2019-12
    win xp电脑如何设置本地网络ip地址

    有时需要设置本地网络IP地址却不知道怎么操作,如果是win xp电脑具体应该怎么设置ip地址呢?下面网连代理小编告诉你!

  • 31 2019-12
    爬虫中使用代理的简单介绍

    1、代理是什么?正向代理:代理客户端获取数据 反向代理:代理服务端提供数据 2、代理的配置,有两种方式进行配置,分别如下:(1)在浏览器中配置配置