一、网络分层协议

经典五层模型

1、物理层:(电脑的硬件,网卡端口,网线,网线连出去的光缆)

定义物理设备如何传输数据

2、数据链路层

在通信的实体间建立数据链路连接。

两台机器物理上是可以连接在一起的,那同时要有配套的软件,通过物理的设备创建一个链路的连接。

3、网络层

为数据在节点之间传输创建逻辑链路

如何我的电脑上访问百度服务器,我们如何去寻找百度这台服务器所在的地址。它就是一个逻辑关系,这个关系是在网络层创建的。

4、传输层

主要有两个协议 TCP/IP,UDP协议。TCP/IP是一个更可高的协议。

传输层向用户提供可靠的端到端(End-to-End)服务。

传输层向高处屏蔽了下层数据通信的细节。

5、应用层

为应用软件提供了很多服务

构建于TCP协议之上

屏蔽网络传输相关的细节。

二、Http协议的发展历史

1、Http/0.9

只有一个命令GET

没有HEADER等描述数据的信息

服务器发送完毕,就关闭TCP连接。

TCP连接对应多个HTTP请求。

2、Http/1.0

增加了获得命令,如POST,PUT

增加status code和header

多字符集支持,多部分发送,权限,缓存等。

3、Http/1.1

持久连接

pipeline(同一个连接发送多个请求,服务端是按顺序返回数据)

增加host(在一台物理服务器,同时跑多个web服务,如node js的web服务,java的web服务)和其他一些命令

4、Http/2

所有的数据以二进制传输。(Http/1.1大部分的数据传输是字符串的)

同一个连接里面发送多个请求不再需要按照顺序来。如同时返回第一个和第二个请求的数据。并行返回,提高了传输效率。

头信息压缩及推送等提高效率的功能。

推送:服务端主动发起数据传输,

推送解决的问题如,web页面有html文本,css,js等内容。先加载解析html文本,在请求css和js文件。有了推送,服务端可以把CSS和JS主动推送到客户端。这样Html和CSS,JS的顺序是并行的,提高传输效率和性能。

三、TCP三次握手

四、URI,URL,URN

1、URI:Uniform Resource Identifier 统一资源标志符。

用来唯一标识互联网上的信息资源

URI包含URL和URN

2、URL: Unifrom Resource Locator 统一资源定位器

如   http://user:pass@host.com:80/path?query=string#hash

ftp://xxxx/yyy

3、URN:永久统一资源定位符

在资源移动之后还能被找到

目前还没有非常成熟的使用方案

五、Http报文样式

1、Http方法

用来定义对于资源的操作

有GET,POST,PUT,DELETE

2、HTTP CODE

定义服务器对请求的处理结果

各个区间的CODE有各自的语义

HTTP 状态码的完整列表

六、创建Web服务

使用node创建

查看node版本

使用Visual Studio Code 创建server.js

const http = require('http');

http.createServer(function(request, response){
console.log('request com', request.url) response.end('123')
}).listen(8888); console.log('server listening on 8888')

  

运行server.js

然后通过浏览器访问

Http协议基础及发展历史的更多相关文章

  1. HTTP 协议基础及发展历史

    一. 5层网络模型介绍 低三层 物理层:主要作用是定义物理设备如何传输数据. 数据链路层:在通信的实体间建立数据链路连接. 网路层:为数据在结点之间传输创建逻辑链路. 传输层: 想用户提供可靠的端到端 ...

  2. HTTP从入门到入土(2)——HTTP协议发展历史

    HTTP协议的发展历史 HTTP/0.9 0.9版本是第一个定稿的HTTP版本,相对较为简陋.它有以下特点: 只有一个命令GET 没有header等描述数据的信息 服务器发送完毕,就关闭TCP连接 注 ...

  3. Web开发技术发展历史

    Web开发技术发展历史   来自:天码营 原文:http://www.tianmaying.com/tutorial/web-history Web的诞生 提到Web,不得不提一个词就是"互 ...

  4. TCP/IP协议基础(转)

    转自 http://www.chinaunix.net 作者:Bernardus160  发表于:2003-12-03 17:33:15 TCP/IP协议基础 -------------------- ...

  5. JavaScript 、ECMAScript、commonJS 发展历史 与标准化发展

    本文介绍下JavaScript和 ECMAScript的诞生及发展历史,以及标准化过程. 一.JavaScript诞生 1994年,网景公司(Netscape)发布了Navigator浏览器0.9版. ...

  6. Linux发展历史

    一.硬件与软件发展历史 计算机由硬件和软件组成结构 硬件 1946年诞生于宾夕法尼亚州,占地170平米,重量达到30吨,名字叫做ENIAC(electronic numerical integrato ...

  7. 【转载】Web开发技术发展历史-版本1

    原文在这里. Web开发技术发展历史 Web的诞生 提到Web,不得不提一个词就是“互联网”.Web是World Wide Web的简称,中文译为万维网.“万维网”和我们经常说的“互联网”是两个联系极 ...

  8. Greenplum 的发展历史

    一.Greenplum的发展历史 Greenplum的发展可以分为下面6个阶段:   图 1 Greenplum时间线 Postgres关系型数据库.Postgres是UC Berkeley开发的关系 ...

  9. .net版本发展历史

    最近装上了VS2013,发现好多新特性.新功能,公司办公还在使用VS2005.VS2008,不过用着也很顺手,在最新版Visual Studio中,微软加入了git源码管理工具,和之前的TFS大体上类 ...

随机推荐

  1. 雷林鹏分享:jQuery EasyUI 数据网格 - 条件设置行背景颜色

    jQuery EasyUI 数据网格 - 条件设置行背景颜色 本教程将向您展示如何根据一些条件改变数据网格(datagrid)组件的行样式.当 listprice 值大于 50 时,我们将为该行设置不 ...

  2. 20175227张雪莹 2018-2019-2 《Java程序设计》第四周学习总结

    20175227张雪莹 2018-2019-2 <Java程序设计>第四周学习总结 教材学习内容总结 一.子类和父类. 1.子类只继承父类中的protected和public访问权限的成员 ...

  3. mysql安装和启动

    1.在cmd的bin目录执行 mysqld --initialize-insecure程序会在动MySQL文件夹下创建data文件夹以及对应的文件2.bin目录下执行,mysqld --install ...

  4. node设置跨域

    开发过程中在build/dev-server.js配置相关代码以跨域 app.use('/api',proxyMiddleware({ target:'http://m.maizuo.com/v4', ...

  5. linux c使用socket进行http 通信,并接收任意大小的http响应(一)

    如何进行http通信呢?我们打开任意一个浏览器,按F12,再选择网络,然后打开任意一个网站,我们就可以看到浏览器和网站通信的过程 如下图: 然后,我们任意点击一条记录,可以看到 然后,查找http协议 ...

  6. 手把手教你实现一个 Vue 进度条组件!

    最近在个人的项目中,想对页面之间跳转的过程进行优化,想到了很多文档或 npm 等都用到的页面跳转进度条,于是便想自己去实现一个,特此记录. 来看下 npm 搜索组件时候的效果: so 下面咱们一起动手 ...

  7. Hadoop学习笔记02_MapReduce练习

    搭建好环境之后 ,就来跑个简单的Mapreduce试试看吧.这个比第一课难多了,需要多多练习并熟练掌握. 需要编写py脚本以及shell脚本, 所以需要学习Python和Linux的Shell编程. ...

  8. 2017-9-3模拟赛T1 卡片(card)

    题目 [题目描述] lrb 喜欢玩卡牌.他手上现在有n张牌,每张牌的颜色为红绿蓝中的一种.现在他有两种操作.一是可以将两张任意位置的不同色的牌换成一张第三种颜色的牌:二是可以将任意位置的两张相同颜色的 ...

  9. elasticsearch 的查询 /_nodes/stats 各字段意思

    /_nodes/stats 字段意思   “”   1 {  2  "_nodes": {3 "total": 1, "successful" ...

  10. erlang工作总结

    总结下自己在做erlang的经验 1.不管什么样的情况下,一定要关注好函数的返回值再来使用,不知道返回值盲目的使用的话,不仅不能达到目标,而且不存在代码/报错提醒.得不偿失. 2.构思好自己的想法,定 ...