HTTP 必考题

一、GET POST 区别

区别一:幂等性(幂等性就是这个操作重复很多遍不会改变结果就是幂等的)

  • 由于 GET 是读,POST 是写,所以 GET 是幂等的(一个数据读100遍和读一遍是一样的),POST 不是幂等的(提交钱,提交一次和100次不一样,会改变结果)。
  • 由于 GET 是读,POST 是写,所以用浏览器打开网页会发送 GET 请求,想要 POST 打开网页要用 form 标签。(POST请求可以用AJAX(常用)或使用form打开新页面)
  • 由于 GET 是读,POST 是写,所以 GET 打开的页面刷新是无害的,POST 打开的页面刷新需要确认(支付宝付款时刷新会有提示让你点确认怕你多打几次钱)。
  • 由于 GET 是读,POST 是写,所以 GET 结果会被缓存(读一个东西,它短时间内结果可能不会变),POST 结果不会被缓存(我给你打100块钱成功了,我再给你打100块钱不能用之前的结果)。
  • 由于 GET 是读,POST 是写,所以 GET 打开的页面可被书签收藏,POST 打开的不行(我收藏了,那是不是要点一下打100块钱)。

区别二:请求参数

  • 通常,GET 请求参数放在 url 里,POST 请求数据放在 body(消息体)里。(POST放到url中也可以,比如数据很少,提交一个name啥的也可以,GET有消息体但是服务器不接收。所以只是一些规定而已)
  • GET 比 POST 更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。(不过body也可以明文)
  • GET 请求参数放在 url 里是有长度限制的,而 POST 放在 body 里没有长度限制。(url长度限制只是浏览器和服务器为了方便而做的,而不是HTTP协议规定的。POST也有长度限制,上传文件提示太大,可以配置支持最大的body只不过很难超过)

区别三:TCP packet

  • GET 产生一个 TCP 数据包(只有head);POST 产生两个或以上 TCP 数据包(既有head又有body)。

根据技术规格文档,GET 和 POST 最大的区别是语义一个读一个写;但面试官一般问的是实践过程中二者的区别,就是上面一堆。

二、HTTP缓存有哪些方案?

缓存分为缓存(强缓存)和内容协商(弱缓存)。

HTTP1.1使用的方案:
最著名的头是:
Cache-Control:max-age = 3600.
只需要在一个文件的响应头写上这句话,他就会自动缓存一个小时(一个小时内如果再次访问同样的URL那么就直接不发请求)。这也是一种web性能优化,不请求即可。

image.png

比如一个网页三年没更新,你只保存了一年的缓存,那缓存海能不能用?
不知道,得去问一下,浏览器问一下这个网页,文件我保存了一年了,过期我要不要把他删掉呢?要删除的话依据是什么呢?有一种选择就是我把文件上传给网站问它能不能删除。但是很傻。
这样:你把文件的特征告诉我,比如把这个文件用MD5算一下哈希,比如说的到ABC,问网站,ABC这个文件(特征值),能不能删除,所以在请求中写一个Etag:ABC.这个Etag是服务器第一次就给我的
。第一次访问网站他会给每一个文件一个特征值,特征值记下来用于后面写上用。
image.png

所以网站会给你两个信息,一个是缓存一年,一个是特征值。一年之后你拿着特征值来问我,我告诉你这个文件能否删除。

如何问呢?
在一年之后你再访问这个缓存的JS的时候,询问我现在存的这个ABC能不能删。
If-None-Match:ABC,浏览器向服务器发的一个询问,所以就是内容协商。如果服务器返回304,就继续用如果返回200那就我给你新的。

HTTP1.0 没人用可能会问到
就是直接写时间,但是如果用户电脑时间错乱就会出问题。就直接失效了。
如果过了这个时间浏览器会给你删掉吗?
它不会给你特征值而是给你这个文件的最新更新时间。
到期后拿着这个时间去给你问要不要删除,同样是304和200.
但是精度容易出问题,比如说我一秒钟更新十次,无法区分到底是不是最新版。

如何不要之前的缓存,改一下URL就可以刷新了。

三、HTTP 和 HTTPS 的区别有哪些?

HTTPS = HTTP + SSL/TLS(安全层)
区别:

  • HTTP 是明文传输的,不安全;HTTPS 是加密传输的,非常安全。
    (HTTP比如说打开一个网站,输入密码,在密码传到服务器的过程中,路由器、电信服务商可以看到我的密码。加密就是过程中谁都看不到。)
  • HTTP 使用 80 端口,HTTPS 使用 443 端口。(因为一个端口只能提供一种服务,当然不一样,具体使用哪个端口早就规定好了)
  • HTTP 较快,HTTPS 较慢。(因为加密了啊)
  • HTTPS 的证书一般需要购买(但也有免费的),HTTP 不需要证书。

具体原理详见:
HTTPS原理以及握手阶段

四、三次握手和四次挥手是什么。

建立TCP连接:我们和百度服务器通信,要先找到IP(IP协议),然后建立一种通信的渠道,这个渠道叫做TCP(传输内容协议),这个通道可以传输任何内容(一般发送HTTP内容:包括请求和响应)。
比如GET发送一个TCP包/POST发送两个包,发送一个响应回来index.js。
TCP可以理解为HTTP(应用层)下面的一层东西,传输层。
所以我们如果要做HTTP的请求和响应,先要建立传输层。

如何建立呢?
A(客户端)和S(服务端),是两个独立的IP,当知道IP时,确认你可以发送TCP的内容才可以建立。

image.png

三次握手简单来说就是确认双方的意向。
A和S之间会有很多数据交流 所以需要加seq序号,
SYN(seq=x)x次想和你同步。
ACK(acknowledge)知道了seq就为x+1表示我知道你x编号对应的想要。

关闭 TCP 连接
四次挥手
我好了(finish)FIN

image.png

建立 TCP 连接时 server 与 client 会经历三次握手
浏览器向服务器发送 TCP 数据:SYN(seq=x)
服务器向浏览器发送 TCP 数据:ACK(seq=x+1) SYN(y)
浏览器向服务器发送 TCP 数据:ACK(seq=y+1)

关闭 TCP 连接时 server 与 client 会经历四次挥手
浏览器向服务器发送 TCP 数据:FIN(seq=x)
服务器向浏览器发送 TCP 数据:ACK(seq=x+1)
服务器向浏览器发送 TCP 数据:FIN(seq=y)
浏览器向服务器发送 TCP 数据:ACK(seq=y+1)

为什么 2、3 步骤不合并起来呢?
答案:2、3 中间服务器很可能还有数据要发送,不能提前发送 FIN。
建立一般是浏览器发起。
结束任一方都可以。
但是一方结束之后另一方不能立马结束,等一下才行。
SYN(synchronous)是TCP/IP建立连接时使用的握手信号。

五、 什么是同源策略和跨域

同源策略是什么?

如果两个 URL 的协议、端口和域名都完全一致的话,则这两个 URL 是同源的。

http://www.baidu.com/s 
http://www.baidu.com:80/sb

/s和/sb是路径 不同路径也是同源,因为HTTP默认80端口,所以不写和写一样。HTTPS是443。

同源策略定义:
浏览器规定
如果JS运行在源A里,那么就只能获取源A的数据
不能获取源B的数据,即不允许跨域。

同源策略怎么做?

只要在浏览器里打开页面,就默认遵守同源策略。

优点

保证用户的隐私安全和数据安全。

缺点

很多时候,前端需要访问另一个域名的后端接口,会被浏览器阻止其获取响应。

比如甲站点通过 AJAX 访问乙站点的 /money 查询余额接口,请求会发出,但是响应会被浏览器屏蔽。

怎么解决缺点

使用跨域手段。

  1. JSONP

    1. 甲站点利用 script 标签可以跨域的特性,向乙站点发送 get 请求。
    2. 乙站点后端改造 JS 文件的内容,将数据传进回调函数。
    3. 甲站点通过回调函数拿到乙站点的数据。
      JSONP优点:改动小只需要改一下JS文件,
      缺点在于不能认证全世界都可以访问,需要加token,JSPON只能发GET请求不支持POST
  2. CORS

    1. 对于简单请求,乙站点(被请求的站)在响应头里添加 Access-Control-Allow-Origin: http://甲站点 即可。
    2. 对于复杂请求,如PATCH 乙站点需要:
      1. 响应 OPTIONS 请求,在响应中添加如下的响应头
        允许甲站点对我进行, POST, GET, OPTIONS, PATCH操作,同时允许甲站点暴露Content-Type

        
        Access-Control-Allow-Origin: https://甲站点
        Access-Control-Allow-Methods: POST, GET, OPTIONS, PATCH
        Access-Control-Allow-Headers: Content-Type
        
        
      2. 响应 POST 请求,在响应中添加 Access-Control-Allow-Origin 头。

    3. 如果需要附带身份信息,JS 中需要在 AJAX 里设置 xhr.withCredentials = true 。这样就会把cookie带到你的请求里面。

详情参考 MDN CORS 文档
POST form-data属于简单请求
POST JSON复杂请求

Nginx 代理 / Node.js 代理
前端 ⇒ 后端 ⇒ 另一个域名的后端
A站点访问B站点服务器,我不允许你的前端访问,我允许你的服务器访问,给你的服务器开一个白名单。所以直接访问A的服务器,服务器访问B,结果拿到再返回给A前端。A的后端配置一个Nginx转发。后端不在浏览器中没有跨域限制,就可以访问B的服务器了。
但是这么做较复杂。

日常工作中用的最对的跨域方案是CORS和Nginx反向代理

六、cookie session localStorage sessionStorage区别

  • cookie VS localStorage
    1、主要区别是 Cookie 会被发送到服务器,而 LocalStorage 不会
    2、Cookie 一般最大 4k,LocalStorage 可以用 5Mb 甚至 10Mb(各浏览器不同)

为什么早期前端使用cookie代替localStorage,因为cookie很早就出了,ls是HTML5中才更新的。
以前遇到需求:把信息存在浏览器中,并且用户刷新数值不会变。只能说用cookie。 比如说弹出一个通知,点过之后不会再出现,就把你点的动作存到cookie中。下次刷新页面不弹。而LS是专门解决这种需求的,所以不用发到服务器且容量较大。

  • LocalStorage V.S. SessionStorage
    LocalStorage 一般不会自动过期(除非用户手动清除)
    SessionStorage 在会话结束时过期(如关闭浏览器之后,具体由浏览器自行决定)
  • Cookie V.S. Session
    Cookie 存在浏览器的文件里,Session 存在服务器的文件里
    Session 是基于 Cookie 实现的,具体做法就是把 SessionID 存在 Cookie 里,ID对应的数据放到服务器中。

Localstorage、sessionStorage、cookie 的区别

七、HTTP/1.1 和 HTTP/2 的区别有哪些?

  1. HTTP/2 使用了二进制传输,而且将 head 和 body 分成来传输;HTTP/1.1 是字符串传输。

  2. HTTP/2 支持多路复用,HTTP/1.1 不支持。多路复用简单来说就是一个 TCP 连接从单车道(不是单行道)变成了几百个双向通行的车道。
    浏览器和服务器中间有100个请求都可以使用同一个TCP连接。
    以前如果有100个请求那就要开100个TCP。

  3. HTTP/2 可以压缩 head,但是 HTTP/1.1 不行。

  4. HTTP/2 支持服务器推送,但 HTTP/1.1 不支持。(实际上没多少人用)

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

推荐阅读更多精彩内容