HTTP

OSI 七层模型指什么 ?

  • OSI(Open System Interconnection):OSI参考模型是国际标准化组织制定的一个用于计算机或通信系统间互联的标准体系,他是一个七层的,抽象的模型体,不仅包括一系列抽象术语概念,也包括具体的协议。
    物理层:为数据设备提供原始比特流的传输通路。
    数据链路层:在通信实体间建立数据链路的链接。
    网络层:负责逻辑寻址和最佳路径选择,负责在网络中两台计算机进行通信时为其选择一条合适的路径,使其准确快速到底目的地。
    传输层:负责端与端节点间的数据传输和控制功能,提供可靠的数据传输服务
    会话层;负责在数据传输中设置和维护电脑网络中两台电脑间的通信连接
    表示层;把数据转换成能与接受者的系统格式兼容并适合传输的数据

HTTP 的工作原理是什么?

  • 浏览器根据dns服务器把域名解析成相应的ip地址,根据ip地址去访问服务器。
  • 浏览器打包用户请求封装成http请求报文,向服务器发送请求。
  • 服务器根据用户请求,生成相应的响应报文发给浏览器。
  • 浏览器解析结果,并渲染在页面上

URI 的格式是什么?常见的协议有哪些?

  • <scheme>://<user>:<password>@<host>:<port>/<path>;<params>?<query>#<hash>
  • scheme指的是常用的协议,如http和https等
  • user和password不是特别常见,不会在URL明文书写用户名和密码,都是通过登录的方式
  • host表示主机的域名
  • port表示端口号
  • path表示资源的路径
  • params,在一些协议中需要参数来访问资源,例如ftp是二进制还是文本传输,参数是名值对,用;隔开
  • query表示get请求最常用的传递参数方式 如:?a=1&b=2&c=3
  • hash可以成为片段,设计为标识文档的一部分 如#aaa
  • 常见的协议有http https file ftp mailto

HTTP 协议有几种和服务器交互的方法

  • get:用于请求服务器发送某个资源
  • head:与get方法类似,但是在服务器的响应中没有资源的内容,只有资源的一些基本信息
  • put;和GET从服务器获取资源相反,PUT用于向服务器写入资源。PUT的语义就是让服务器用请求的主体部分创建一个请求URL命名的文档
  • post:POST用于想服务器发送数据,通常用来支持HTML的表单(input、select、textarea),表单中的数据会被发送到服务器
  • trace:TRACE:经过过防火墙、代理、网关和一些其它应用程序修改后的最终请求的样子;
  • DELETE方法用于要求服务器删除请求的URL
  • OPTIONS方法用于请求 web服务器告知其支持的各种功能

状态码200,301, 304,403,404,500,503分别代表什么意思

  • 200:表示ok,对get和post请求的应答文档跟在后面
  • 301:重新定向,一般是域名变了,然后服务器会跳转到新页面上
  • 304:页面依旧使用以前的缓存(有时候测试过程中不需要缓存,勾选* disable cache选项就不会有304了)
  • 403错误会禁止访问,但错误种类有很多,可能是ip被拒绝、服务器限制人数、客户证书失效等等原因导致
  • 404:页面不存在
  • 500:服务器内部错误
  • 505:服务器正在维护

报文有哪几部分组成?

  • 对报文进行描述的起始行 —— start line
  • 包含属性的首部块 —— header
  • 可选的包含数据的主体部分 —— body

请求头的格式和作用是什么?给个范例截图说明

  • 格式:键/值的形式;
  • 作用:为请求添加额外的信息,来告诉服务器客户端的信息和能力,服务器可以据此为客户端提供更好的响应
Paste_Image.png

主体的作用是什么?给个范例

  • 主体就是客户端和服务器传输的主要内容,包括视频,图片,文本等
Paste_Image.png
  • 简述浏览器缓存是如何控制的
  • 缓存的作用:让不需要经常更换的内容缓存,可以提高页面加载的速度
    先根据(cache-control/Expires)查看浏览器缓存是否过期。
    过期了再向服务器发送请求,服务器根据If-Modified-sINCE和If-None-Match判断是否返回304,让浏览器从缓存中调取还是返回200,发送响应请求,
    浏览器渲染页面
    Cache-Control与Expires

Cache-Control与Expires的作用一致,都是指明当前资源的有效期,控制浏览器是否直接从浏览器缓存取数据还是重新发请求到服务器取数据。只不过Cache-Control的选择更多,设置更细致,如果同时设置的话,其优先级高于Expires。
Last-Modified/ETag与Cache-Control/Expires

配置Last-Modified/ETag的情况下,浏览器再次访问统一URI的资源,还是会发送请求到服务器询问文件是否已经修改,如果没有,服务器会只发送一个304回给浏览器,告诉浏览器直接从自己本地的缓存取数据;如果修改过那就整个数据重新发给浏览器;
Cache-Control/Expires则不同,如果检测到本地的缓存还是有效的时间范围内,浏览器直接使用本地副本,不会发送任何请求。两者一起使用时,Cache-Control/Expires的优先级要高于Last-Modified/ETag。即当本地副本根据Cache-Control/Expires发现还在有效期内时,则不会再次发送请求去服务器询问修改时间(Last-Modified)或实体标识(Etag)了。
一般情况下,使用Cache-Control/Expires会配合Last-Modified/ETag一起使用,因为即使服务器设置缓存时间, 当用户点击“刷新”按钮时,浏览器会忽略缓存继续向服务器发送请求,这时Last-Modified/ETag将能够很好利用304,从而减少响应开销。
无法被浏览器缓存的请求:

HTTP信息头中包含Cache-Control:no-cache,pragma:no-cache,或Cache-Control:max-age=0等告诉浏览器不用缓存的请求
需要根据Cookie,认证信息等决定输入内容的动态请求是不能被缓存的
经过HTTPS安全加密的请求(有人也经过测试发现,ie其实在头部加入Cache-Control:max-age信息,firefox在头部加入Cache-Control:Public之后,能够对HTTPS的资源进行缓存,
POST请求无法被缓存
HTTP响应头中不包含Last-Modified/Etag,也不包含Cache-Control/Expires的请求无法

Paste_Image.png

下图各个参数什么意思

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

推荐阅读更多精彩内容