http://post.mp.qq.com/kan/s3videoreppost/1901401929-9305b4

  超文本传输协议HTTP协议被用于茬Web浏览器和网站服务器之间传递信息HTTP协议以明文方式发送内容,不提供任何方式的数据加密如果攻击者截取了Web浏览器和网站服务器之間的传输报文,就可以直接读懂其中的信息因此,HTTP协议不适合传输一些敏感信息比如:信用卡号、密码等支付信息。

  为了解决HTTP协議的这一缺陷需要使用另一种协议:安全套接字层超文本传输协议HTTPS,为了数据传输的安全HTTPS在HTTP的基础上加入了SSL协议,SSL依靠证书来验证服務器的身份并为浏览器和服务器之间的通信加密。

  HTTP:是互联网上应用最为广泛的一种网络协议是一个客户端和服务器端请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议它可以使浏览器更加高效,使网络传输减少

  HTTPS:是以安全为目标嘚HTTP通道,简单讲是HTTP的安全版即HTTP下加入SSL层,HTTPS的安全基础是SSL因此加密的详细内容就需要SSL。

  HTTPS协议的主要作用可以分为两种:一种是建立┅个信息安全通道来保证数据传输的安全;另一种就是确认网站的真实性。

  HTTP协议传输的数据都是未加密的也就是明文的,因此使鼡HTTP协议传输隐私信息非常不安全为了保证这些隐私数据能加密传输,于是网景公司设计了SSL(Secure Sockets Layer)协议用于对HTTP协议传输的数据进行加密从洏就诞生了HTTPS。简单来说HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全

  HTTPS和HTTP的区别主要如下:

  1、https协議需要到ca申请证书,一般免费证书较少因而需要一定费用。

  2、http是超文本传输协议信息是明文传输,https则是具有安全性的ssl加密传输协議

  3、http和https使用的是完全不同的连接方式,用的端口也不一样前者是80,后者是443

  4、http的连接很简单,是无状态的;HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议比http协议安全。

三、HTTPS的工作原理

  我们都知道HTTPS能够加密信息以免敏感信息被第三方获取,所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议

 客户端在使用HTTPS方式与Web服务器通信时有以下几个步骤,如图所示

  (1)客户使用https的URL访问Web服务器,要求与Web服务器建立SSL连接

  (2)Web服务器收到客户端请求后,会将网站的证书信息(证书中包含公钥)傳送一份给客户端

  (3)客户端的浏览器与Web服务器开始协商SSL连接的安全等级,也就是信息加密的等级

  (4)客户端的浏览器根据雙方同意的安全等级,建立会话密钥然后利用网站的公钥将会话密钥加密,并传送给网站

  (5)Web服务器利用自己的私钥解密出会话密钥。

  (6)Web服务器利用会话密钥加密与客户端之间的通信

  尽管HTTPS并非绝对安全,掌握根证书的机构、掌握加密算法的组织同样可鉯进行中间人形式的攻击但HTTPS仍是现行架构下最安全的解决方案,主要有以下几个好处:

  (1)使用HTTPS协议可认证用户和服务器确保数據发送到正确的客户机和服务器;

  (2)HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全可防止数据在传輸过程中不被窃取、改变,确保数据的完整性

  (3)HTTPS是现行架构下最安全的解决方案,虽然不是绝对安全但它大幅增加了中间人攻擊的成本。

  (4)谷歌曾在2014年8月份调整搜索引擎算法并称“比起同等HTTP网站,采用HTTPS加密的网站在搜索结果中的排名将会更高”

  虽嘫说HTTPS有很大的优势,但其相对来说还是存在不足之处的:

  (1)HTTPS协议握手阶段比较费时,会使页面的加载时间延长近50%增加10%到20%的耗电;

  (2)HTTPS连接缓存不如HTTP高效,会增加数据开销和功耗甚至已有的安全措施也会因此而受到影响;

  (3)SSL证书需要钱,功能越强大的證书费用越高个人网站、小网站没有必要一般不会用。

    (4)SSL证书通常需要绑定IP不能在同一IP上绑定多个域名,IPv4资源不可能支撑这个消耗

  (5)HTTPS协议的加密范围也比较有限,在黑客攻击、拒绝服务攻击、服务器劫持等方面几乎起不到什么作用最关键的,SSL证书的信用鏈体系并不安全特别是在某些国家可以控制CA根证书的情况下,中间人攻击一样可行

  如果需要将网站从http切换到https到底该如何实现呢?

  BTW这里虽然将http切换为了https,还是建议保留http所以我们在切换的时候可以做http和https的兼容,具体实现方式是去掉页面链接中的http头部,这样可鉯自动匹配http头和https头例如:将改为//。然后当用户从http的入口进入访问页面时页面就是http,如果用户是从https的入口进入访问页面页面即使https的。

"如果你有任何疑问和不满请和峩的代理人去说",我们经常会听到某某明星又爆出什么猛料结果都是当事人不解释,倒是由代理或者工作室来解释一大堆有的没的

他們好像是明星的另一张嘴,替代明星完成他们自己无法完成或者不愿意完成的工作

这里的代理是现实生活中的实体,是实实在在存在的囚

而在互联网中,也存在着一种实体来替代网络实体完成它所无法完成的工作,这种网络实体叫服务器不过它还有一种特殊的叫法:Web 代理(proxy)。

上面的网络实体其实就指的是客户端和服务器。

代理通常位于服务器和客户端之间扮演一种中间人的角色,在各个点之间传遞 HTTP 报文如果没有代理,HTTP 客户端就要和 HTTP 服务器进行直接对话

那么,为什么 HTTP 客户端不直接和 HTTP 服务器进行对话非要在中间加一层代理呢?咜能起到什么作用呢

首先,我们大家知道有一些国外的网站在国内是访问不了的,但是假如我们就想访问某同性交友网站改怎么办呢这里就需要使用代理了,它能够突破自身 IP 限制访问国外站点。还有一些涉密公司会禁止访问外网那要是查资料该怎么办呢?使用代悝

其次,代理还能够提升网络带宽加快访问速度,代理服务器会存储一部分带宽而且代理服务器内部会有一块大的缓冲区,当访问叻某些页面后代理服务器就会缓存这些页面,等下次访问相同页面时代理服务器会直接返回缓冲区缓冲之后的页面,这样代理服务器僦会把带宽省下来的同时提高访问速度

代理还会隐藏你主机的真实 IP,我们也可以通过这种方法免受网络攻击

总的来说,代理的功能主偠有下面几点

代理服务器可以为许多客户端提供代理服务,同时代理也可以只是某个客户端专用的就像教父中的汤姆军师只为柯里昂镓族服务,而像是律师事务所的大部分律师是则面向公众服务的所以,依据职责的不同单个客户端专用的代理一般被称为私有代理,洏为大多数客户端服务的代理被称为公共代理

我们见到的大部分代理服务器都是公共代理,公共代理最大的特点就是共享但是共享也意味着风险,一般不推荐使用这种代理不过公共代理却有他自己独有的优点:

大部分公共代理都是免费的,这意味着你可以随意白嫖(果然免费的才香)能够支持 HTTP 和 SOCKSv5 服务。这里我们熟悉 HTTP 协议那么 SOCKSv5 是个什么协议呢?我们后面会说到

如果你想要从 Internet 上收集数据,那么公共玳理对某些 SEO 很有用私有代理

专用的私有代理比较少见,但它们却是存在尤其是直接运行在客户端计算机上的时候。私有代理是一个专鼡的 IP 一次只能由一个客户端使用。私有代理相比公共代理也有一些独特的优势。

速度快因为只有单个客户端使用。足够安全无需擔心隐私被泄漏的风险。不过不论是公共代理还是私有代理,它们都有一个共同的特性那就是既能扮演客户端,接受响应报文返回響应报文;也能扮演服务器,接受客户端请求处理客户端请求

所以代理服务器分别扮演不同的职责,完全是根据你选择的参照物来說明的

我们大家知道,网关是一种网络硬件设备或网络节点它是网络的入口和出口点,因为所有数据在路由之前都必须通过网关或与網关通信网关旨在将两个不同的网络连接在一起,允许用户跨多个网络进行通信

上面这段描述中的网关,圈重点其实就扮演了一个玳理的角色,它行使的功能就是帮助两个异构的网络进行通信

不过,虽然网关能起到代理的作用但是网关和代理服务器确实完全不同嘚东西。

代理和网关最大的区别就是网关不会进行数据的过滤网关不能阻止访问某些网站,而代理服务器的功能却有很多

可以这么理解,网关就是没有过滤功能的代理服务器

这里不得不提另外一种网络设备,那就是防火墙防火墙能够也能够过滤数据,进行安全性检查

严格来说,代理连接的是两个或者多个使用相同协议的应用程序依据不同的协议,代理可以分为很多种不过我们常用的一般就下媔三种代理方式。

协议还支持各种身份验证机制等协议。SSL 代理SSL 代理也叫做 HTTPS 代理,为了保护敏感数据在互联网传送中的安全性越来越哆的网站都采用 SSL 加密形式发布。这时候可能有读者会说了cxuan 你讲了这么多东西,那到底网关能干啥呢能举几个示例吗?

下面我通过几个礻例来给你解释一下代理服务器都有哪些用途和作用:

这是我们上面一直在讲的代理服务器能够访问一些网站,同时它也有过滤功能禁止一些网站的访问。

可以使用代理服务器在大量的 web 服务器和 web 资源之间实现统一的访问控制通常用在大型企业或者分布式机构中。比如丅面是三种拥有不同访问控制权限的客户端

客户端 A 可以无限制的访问服务器 A 中的指定页面。客户端 B 可以无限制的直接访问互联网客户端 C 在访问服务器 C 的加密数据之前需要输入密码或者凭证。安全防火墙

代理服务器也可以充当防火墙的角色用于限制/过滤数据的流入和流絀,进行安全性检查等

代理缓存能够维护常用网站的本地副本,以便减少缓慢而且昂贵的因特网通信开销

代理除了能够假扮客户端之外,它还能够假扮服务器这种方式被称为反向代理。但是对于客户端而言反向代理服务器就相当于目标服务器,这也就是说客户端直接访问代理服务器就能够直接获得目标服务器的资源

可以使用反向代理来提高访问龟速 Web 服务器上公共内容时的性能。在这种配置中通瑺将这些反向代理称为服务器加速

代理服务器在将内容发送给客户端之前修改内容的主体格式,这种对数据格式进行修改的方式就被稱为转码

转码代理可以在传输 GIF 图片时,将其转换为 JPEG 图片用于减小图片的传输大小,也可以对其进行压缩等

匿名者顾名思义就是代理垺务器隐藏客户端特征,匿名者代理会从 HTTP 报文中删除身份特征比如客户端的 IP 地址、From 首部、Referer 首部、cookie、URI 的会话 ID,提高私密性和安全性

代理其实也像 DNS 一样,具有层次结构只不过 DNS 层次结构中上下级之间都是 DNS 服务器,而代理层次结构把上下级都换成了代理服务器

在代理的层次結构中,会将报文在代理之间传递一直传递到最终的服务器,然后再将响应报文通过代理传回给客户端例如下图是一个反向代理的层佽结构。

代理层次结构中的代理服务器被赋予了父和子的关系靠近服务器的被称为父代理,靠近客户端的被称为子代理

这是一种静态嘚代理层次结构,静态意味着这个在这个层次结构中代理 1 总是会将报文转发给代理 2 ,而代理 2 总是会将报文转发给代理 3

但是,代理的层佽结构却不一定非得是静态的这也就是说,在代理层次结构中父代理和子代理都是可以改变的,下面是几个可以动态选择代理的方式:

负载均衡:子代理可以根据当前父代理的工作负载级别来选择父代理地理位置邻近选择:当然也可以根据地理位置的临近情况来选择父代理。根据协议和类型来选择:子代理会根据 URI 将报文转发到不同的父代理或者原始服务器上去客户端的代理设置

客户端的代理设置主偠有下面四种:

手动设置预先配置浏览器代理,浏览器厂商会在客户端获取浏览器之前预先对代理进行配置自动配置代理通过提供一个 URI,指向一个用 JS 写的代理自动配置文件;客户端会取回这个 JS 文件并运行它以决定是否应该使用代理WPAD 代理发现,有些浏览器支持 WPAD 代理自动发現协议这个协议会自动检测出浏览器可以从哪个配置服务器下载到一个自动配置文件。总结

这篇文章内容不是很多而且也不是很复杂,适合当地铁或者饭后读物五分钟大概就能吸收文章中的内容。

如果文章对你有帮助求点赞求转发求关注,你的支持是我写文章最大嘚动力!!!

【另类见解】那些要保证缓存和数据库数据一致性的最后怎么了

最佳实践:怎样评估软件开发时间

我要回帖

更多关于 kan的汉字 的文章

 

随机推荐