HTTP

一、说一下HTTP

  • HTTP是应用层的协议。
  • 是基于TCP的,所以也需要先建立TCP的连接,再发送HTTP的请求。
  • HTTP的请求报文分成三部分,第一部分是请求行,第二部分是请求的首部,第三部分才是请求的正文实体。
    1、在请求行中,标明了HTTP的版本、URL,还有方法。
      a.方法最常用的有GET,就是从服务端中获取一些资源。
      b.另一种方法就是POST,它主动向服务器推一些数据,内容一般放在正文中。
      c.还有一种方法是PUT,就是向指定资源位置上传最新内容。
      d.还有一种是DELETE,用来删除资源。
    2、首部是key value的结构。
      a.Accept-Charset,表示客户端可以接受的字符集,防止传过来的是另外的字符集,从而导致乱码。
      b.Content-Type,表示正文的格式,比如说JSON。
  • 浏览器会通过socket将HTTP请求报文交给传输层,通过网络协议栈层层处理后,发送给相应的服务器。
  • HTTP的返回报文也分为三部分,状态行、首部、正文实体。
    1、状态行中,标明了状态码、HTTP版本等信息。
      a.状态码反映了HTTP请求的结果。200表示成功,404表示服务器无法响应这个请求。
    2、首部是key value的数据结构。
      a.里面也有Content-Type,表示正文的格式,比如是HTML还是JSON。

二、说一下HTTP 2.0

  • HTTP 2.0在HTTP 1.1的基础上进化。
  • HTTP 1.1在每次通信时,都需要携带完整的头部信息,HTTP 2.0对HTTP的头进行了压缩,方法是将每次都需要携带的key value在两端做一个索引表,相同的头只发送索引表中的索引。
  • HTTP 2.0将一个TCP连接分成多个流,每个流有自己的ID,而且流可以是客户端发往服务端,也可以是服务端发给客户端。流其实是一个虚拟的通道。
  • HTTP 2.0还将传输信息分割成更小的消息和帧,并采用二进制格式编码。比如说Header帧,传输Header的内容,Data帧,传输正文实体。
  • HTTP 1.1的请求是串行的,下一个请求的发送需要等待上一个请求的相应;HTTP 2.0通过分流和拆解传输信息,实现了在一个连接里,客户端和服务端可以同时发送多个请求或响应,且不用按照顺序一对一对应。
  • 所以,HTTP 2.0也解决了队首堵塞的问题,不需要使用多条TCP连接来实现并行请求和响应,减少了TCP连接数对于服务器性能的影响。

三、说一下HTTPS

  • HTTPS就是在HTTP协议的基础上,对通信进行加密的协议。
  • 加密的方式一般有非对称加密和对称加密。
    1、对称加密,指的是加密和解密使用的是同一个密钥。
    2、非对称加密,指的是加密和解密不使用同一个密钥。一把作为公开的公钥,一把作为谁也不能给的私钥。公钥加密的信息,只有私钥能解,私钥加密的信息,只有公钥能解。
  • 对称加密相比非对称加密而言,效率和性能都更好。
  • 所以HTTPS先用非对称加密,使通信双发约定好公钥,然后在后续的大量数据通信中就使用这个公钥来对称加密。
    a. 首先,客户端会先向服务器打招呼,并传给他自己的TSL层版本,可以使用的密码套件,还有一个随机数。client hello
    b. 服务端收到后,会返回一个消息,包括服务端选择协议版本、加密套件压缩算法,也发送给客户端一个随机数。server hello
    c. 随后,服务端会发送他的证书给客户端。server certificate
    d. 然后服务端表示自己发送信息结束了。server done
    e. 客户端收到证书后,对证书进行校验。使用浏览器中内置的CA公钥,去解密服务端发来的证书。如果能成功,说明是可信的。客户端也把自己的证书发给服务端进行校验。client certificate
    f. 客户端又产生一个随机数字pre-master,用证书中的公钥加密,再发给服务端,并要求更改后续的加密方式。client key exchange
    g. 在客户端和服务端,通过刚刚发送和接收的三个随机数,以及所选择的密码套件加密算法,生成相同的对称密钥。
    h. 然后客户端发消息表示,以后就用对称密钥传输了。change cipher spec
    i. 然后使用协商好的对称密钥,发一些参数给服务端用于数据和握手验证。Encypted Handshake Message
    j. 服务端也向客户端表示,以后使用对称加密传输。change cipher spec
    k. 然后使用对称密钥发参数给客户端。Encypted Handshake Message

四、数字证书

  • 数字证书是由权威部门CA颁发的。
  • 证书里面有公钥、证书所有者、证书有效期、发布机构等信息,就像身份证一样。
  • 服务器可以向CA进行证书申请,然后CA会用私钥给证书进行签名。
  • 客户端获得服务器的CA证书后,可以使用CA的公钥对其解密。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容