您当前的位置:首页 > 电脑百科 > 网络技术 > 网络知识

一文带你入门网络协议

时间:2022-05-17 09:54:37  来源:51CTO  作者:
一文带你入门网络协议

 

1.目录

  • 网络协议
  • HTTP
  • HTTPS

希望通过这篇文章能让读者了解什么是网络协议,以及目前我们最常接触的 http 和 https。

2.网络协议

网络协议是为计算机网络中进行数据交换而建立的规则、标准或约定。

众所周知,网络是一台台的计算机构成的一张“大网”,彼此通讯,交互数据。我们也都知道不同的计算机厂家生产的计算机肯定是存在差异的,那么它们是如何克服这些差异进行通信呢?显然就是“语言”,我们的语言能彼此交流是因为我们对这些定义产生了共识,比如苹果指代的就是具体的一种水果等等。而计算机也是通过建立这种约定来完成通信的。不过要注意!这网络协议不仅仅是给计算机互相间使用的,而是给网络上所有设备(服务器、个人PC、交换机、路由器、防火墙等)使用的。大多数网络都采用分层的体系结构,每一层都建立在它的下层之上,向它的上一层提供一定的服务,而把如何实现这一服务的细节对上一层加以屏蔽(这就类似我们代码中的接口)。一台设备上的第 n层与另一台设备上的第n层进行通信的规则就是第n层协议。在网络的各层中存在着许多协议,接收方和发送方同层的协议必须一致,否则一方将无法识别另一方发出的信息。网络协议使网络上各种设备能够相互交换信息。上面提到了大多数网络都采用分层,这里说下分层模型:

  • OSI 模型(Open System Interconnection Reference Model),一种概念模型,由国际标准化组织提出,是一个试图使各种计算机在世界范围内互连为网络的标准框架。它具体分为七层:
  • 应用层(第七层)
  • 为应用软件而设的接口,用于应用间的通信
  • 表示层(第六层)
  • 将数据转为接收系统可以使用的格式
  • 会话层(第五层)
  • 会话层是建立在传输层之上,利用传输层提供的接口,使应用建立和维持会话,并能使会话获得同步(简单理解成数据传输的一个通道)
  • 传输层(第四层)
  • 将传输表头(TH,传输表头包含了所使用的协议等信息)加至数据(我们要传输的数据)形成数据包
  • 网络层(第三层)
  • 网络层决定了数据的传输路径和转寄,它会将网络表头(NH,包含了网络数据:IP 等)加入数据包中
  • 数据链路层(第二层)
  • 数据链路层(Data Link Layer)负责网络寻址、错误侦测和改错物理层(第一层)
  • 物理层确保原始数据可以在各种物理媒体上传输

TCP/IP 协议族分层方式与 OSI 分层的同异,如下图:

一文带你入门网络协议

 

下面会对一个简单的场景进行网络请求画图。

场景:我给公司写了一个 hello world 的简单的静态页面部署在公司的服务器上,我用自己的电脑在家里通过公网访问这个静态页面,比如网址是“http://www.xxx.com”。

当我访问这个网址时,浏览器都做了些什么呢?我们看下图:

一文带你入门网络协议

 

TCP

TCP(Transmission Control Protocol,传输控制协议)是一种面向连接的,可靠的,基于字节流的,双向传输的传输层通信协议。它在建立连接时会经过三次握手,三次握手完成后才会开始传输数据;在终止连接时,它需要四次挥手。具体如下:

(1)建立连接

一文带你入门网络协议

图源:百度百科

三次握手:

  • 客户端发送 SYN 报文给服务端,进入 SYN_SEND 状态
  • 服务器回复 SYN,进入 SYN_RECV 状态
  • 客户端收到来自服务端的 SYN 报文后,回复 ACK

客户端和服务端进入 Established 状态,可以开始收发数据了。

(2)终止连接

一文带你入门网络协议

图源:百度百科

  • 四次挥手(注意:close 动作可以由任意一端先发起,这里以 client 发起为例):
  • 客户端先调用 close,执行 active close,并发送 FIN 表示数据发送完毕,进入 FIN_WAIT_1 状态
  • 服务端接收到 FIN 后,执行 passive close,并给客户端发送 ACK,进入 CLOSE_WAIT 状态
  • 服务端给客户端发送一个 FIN,进入 LAST_ACK 状态

主动发起 close 的一方负责最终确认 FIN,这个例子就是客户端需要接收 FIN 并回复 ACK 给服务端,进入 TIME_WAIT 状态,服务端收到 ACK 后进入 CLOSED 状态

为什么终止的时候是四次挥手呢?

因为一方主动发起 close 并发送 FIN 仅仅代表它不再发送数据,可是还能接收数据,所以需要另一方也进行 close 并发送 FIN 通知对方。至于为什么要将 ACK 和 FIN 分开呢?是因为 ACK 是告诉对方“我知道了”,而 FIN 是告诉对方“我也没有数据给你了”。而实际情况不一定是我收到 FIN 就刚好也把数据都给完对方了,所以是需要分开的。

HTTP

HTTP(HyperText Transfer Protocol),超文本传输协议,它是基于 TCP 协议实现的。

HTTP 是一种无状态协议,像我们作为游客访问一个页面时,无状态协议是简单且高效的。不过像电商场景是需要记录用户登录状态或记录购物车商品信息的(除了电商像一些中台系统也是需要记录用户状态的,这里仅是举例),这时就需要一些额外的技术协助了,如:Cookie。

HTTP 报文格式

HTTP 协议的请求报文和响应报文的结构基本相同。

报文由三大部分组成:

  • 起始行
  • 描述请求或响应的基本信息,如:GET /** HTTP/1.1、HTTP/1.1 200 OK 等
  • 头部字段集合
  • 使用 key-value 说明报文(想想请求头和响应头)
  • 消息正文

HTTPS

HTTP 是基于 TCP 实现的,它的报文是明文,整个传输过程完全是透明的,任何环节都可以轻松获截、修改,这是很不安全的。因此,安全的 HTTP 协议应运而生—— HTTPS。HTTPS其实就是在HTTP之上增加了SSL。

(1) SSL/TLS

SSL 即安全套接层(Secure Sockets Layer),1999年改名为 TLS(传输层安全, Transport Layer Security)

有几个概念要先说清楚:

  • 对称加密
  • 通过同一把“钥匙”进行加密和解密
  • 非对称加密
  • 有两把“钥匙”——公钥,私钥,使用公钥加密的,需要使用私钥解密;使用私钥加密的,需要公钥解密
  • 摘要算法
  • 将一个随机长度的内容生成一个定长的内容,常见算法有:MD5、sha1、sha2等等
  • 安全性
  • 没有绝对的安全,我们所说的数据安全都是基于一个信任点,认为它是安全的,我们所说的安全才能成立,否则不存在安全一说。如:非对称加密和对称加密,我们相信这些算法的安全性,因此认为只要密钥不泄露,那么就是安全的

(2)HTTPS 工作流程大致如下:

先完成三次握手,这里和 HTTP 是一致的

  • 浏览器给服务器发送加密套件列表(就是告诉服务器自己支持的加密算法)
  • 服务器根据加密套件列表挑选加密算法,并给浏览器发送公钥
  • 浏览器获取公钥后,随机生成对称加密算法使用的密钥,通过公钥加密该密钥,然后发送密文给服务器
  • 服务器使用私钥解密,对于该会话的内容信息都使用该密钥加密传输给浏览器

(3)优点

  • 通过非对称加密保证浏览器传输的密钥不会被破解(因为私钥在自己手上,没有经历过网络传输)
  • 使用对称加密算法加解密内容效率高

(4)缺点

  • 服务器给浏览器传输公钥时没法保证该浏览器不会泄露公钥

基于这个缺点,我们需要依赖第三方机构协助,让我们的 HTTPS 更安全可靠。

具体如下:

  • 对于第三步的传输公钥改成传输公钥数字证书
  • 数字证书组成:

公钥用户信息

公钥

签名

通过 hash(公钥,公司信息,域名等申请信息) 获取数据摘要;CA 再对摘要信息进行加密,这个密文就是签名

CA 信息

有效期

证书序列号

  • 数字证书由第三方机构(CA 机构)颁发
  • 公司信息、系统的域名和公钥需要到 CA 机构进行认证,认证通过后 CA 再给我们颁发证书,证书内容如上不累述。因为这证书有签名,所以证书内容不可被篡改,从而证书里面的公钥用户信息和公钥的安全性就得到了保证。
  • CA 机构颁发的证书的可靠性依赖于根证书,而根证书是操作系统或浏览器内置的(换句话说,我们就是要相信操作系统或者浏览器的安全性)

综上所述,我们 HTTPS 的安全性是基于对根证书的信任和加密算法的信任,从而认为自己是安全的。

上面也提到了,基于某个信任点,我们的安全才能聊下去,所以是没有绝对的安全的。如果黑客劫持了浏览器,让你所有请求先到他,他再到服务器,那么你请求的所有数据都会先到黑客手上,那么就不安全了。举例:我们的梯子很多就是代理,浏览器发出的请求被它代理,然后走到可以翻墙的服务器上再去请求资源,得到的数据自然也是原路返还,那么这个中转服务器就可以做很多操作了。

相信到这里,大家已经知道我们常说的网络分层架构一般是定义成5层或者7层,而我们所说的网络协议是针对里面某一层的通信协议。这里以我们最常接触的 http 和 https 为例做了说明,并且讲了它们的区别,还延申了下网络安全方面的内容。

作者介绍

蔡柱梁,51CTO社区编辑,从事JAVA后端开发8年,做过传统项目广电BOSS系统,后投身互联网电商,负责过订单,TMS,中间件等。



Tags:网络协议   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
从零开始了解网络协议:TCP/IP详解
从零开始了解网络协议:TCP/IP详解 在当今数字化的时代,网络协议已经成为我们生活中不可或缺的一部分。作为互联网的基础,网络协议规定了数据如何在不同的网络设备之间传输。TC...【详细内容】
2024-02-01  Search: 网络协议  点击:(62)  评论:(0)  加入收藏
一图看完8种常用网络协议
今天我们来聊聊网络协议。1. OSI模型网络协议是网络中两台计算机之间传输数据的标准语言。各种计算机系统使用 OSI(Open Systems Interconnection)模型规定的标准相互通信。OS...【详细内容】
2023-10-09  Search: 网络协议  点击:(157)  评论:(0)  加入收藏
几个常见的计算机网络协议
随着互联网的迅速发展,计算机网络协议成为我们日常使用网络的基础。在这篇科普文中,我们将介绍几个常见的计算机网络协议,包括TCP/IP、HTTP和FTP,以及它们在网络通信中的作用。T...【详细内容】
2023-09-28  Search: 网络协议  点击:(191)  评论:(0)  加入收藏
深入浅出RPC服务 | 不同层的网络协议
导读:本系列文章从RPC产生的历史背景开始讲解,涉及RPC核心原理、RPC实现、JSF的实现等,通过图文类比的方式剖析它的内部世界,让大家对RPC的设计思想有一个宏观的认识。作者:王禹...【详细内容】
2023-03-24  Search: 网络协议  点击:(204)  评论:(0)  加入收藏
一文带你入门网络协议
1.目录 网络协议 HTTP HTTPS希望通过这篇文章能让读者了解什么是网络协议,以及目前我们最常接触的 http 和 https。2.网络协议网络协议是为计算机网络中进行数据交换而建立...【详细内容】
2022-05-17  Search: 网络协议  点击:(465)  评论:(0)  加入收藏
网络协议之:基于UDP的高速数据传输协议UDT
简介简单就是美。在网络协议的世界中,TCP和UDP是建立在IP协议基础上的两个非常通用的协议。我们现在经常使用的HTTP协议就是建立在TCP协议的基础上的。相当于TCP的稳定性来说...【详细内容】
2021-12-06  Search: 网络协议  点击:(545)  评论:(0)  加入收藏
Wireshark for Mac(网络协议分析软件)v3.5.0rc0-2716中文免费版
Wireshark 中文版是一款mac网络协议分析软件,任何负责的网络分析人员都对这个软件情有独钟。如今,几乎没有哪种产品像它这样拥有如此持久的魅力,很容易看出其中的原因。网管员...【详细内容】
2021-08-20  Search: 网络协议  点击:(372)  评论:(0)  加入收藏
每一次聊天刷视频背后的基础设施——七层网络协议
想象一下今天是个无聊的周末,而你正躺在床上无聊的刷着头条或者抖音。同样的视频不停推荐,你百无聊赖,好奇这些视频是如何发送的。1、你得有一个手机,手机中有一个模块叫无线网...【详细内容】
2021-07-20  Search: 网络协议  点击:(355)  评论:(0)  加入收藏
Wireshark for Mac(网络协议分析软件)v3.5.0rc0-2136中文免费版
Wireshark 中文版是一款mac网络协议分析软件,任何负责的网络分析人员都对这个软件情有独钟。如今,几乎没有哪种产品像它这样拥有如此持久的魅力,很容易看出其中的原因。网管员...【详细内容】
2021-06-11  Search: 网络协议  点击:(301)  评论:(0)  加入收藏
网络协议私人订制的DNS服务:需要HTTPDNS 吗?
全球统一的 DNS 是很权威,但是我们都知道“适合自己的,才是最好的”。很多时候,标准统一化的 DNS 并不能满足我们定制的需求,这个时候就需要 HTTPDNS 了。然而,我们信任的地址簿...【详细内容】
2021-04-09  Search: 网络协议  点击:(356)  评论:(0)  加入收藏
▌简易百科推荐
学生偷看“不良网站”,手机上3个痕迹无法清除,网友:咋不早说
众所周知,中国的常规教育中,总是“谈性色变”,但在这个信息爆炸的互联网时代,即便是一些年纪很小的孩子,也能轻易接触到一些所谓的不良网站,因此这一方面的教育缺失,其实是很可怕的...【详细内容】
2024-03-28    叶姐生活指南  Tags:不良网站   点击:(19)  评论:(0)  加入收藏
什么是网络中的路由器?核心功能解释
路由器是互联网连接的核心元素,是一种允许多个设备连接到互联网,并促进将数据包转发到各自的目标地址的设备。使用动态路由技术,路由器检查数据并在各种可用路径中选择最有效的...【详细内容】
2024-03-07    千家网  Tags:路由器   点击:(36)  评论:(0)  加入收藏
过年该不该升级Wi-Fi 7路由?看完就知道
打开电商网站不难发现,从2023年第三季度到现在,Wi-Fi 7路由器新品越来越多。而且价格不再是高高在上,已经基本和Wi-Fi 6路由价格差不多了。看到这些Wi-Fi 7新品路由,不少朋友就...【详细内容】
2024-02-27    中关村在线  Tags:Wi-Fi   点击:(45)  评论:(0)  加入收藏
聊聊 Kubernetes 网络模型综合指南
这篇详细的博文探讨了 Kubernetes 网络的复杂性,提供了关于如何在容器化环境中确保高效和安全通信的见解。译自Navigating the Network: A Comprehensive Guide to Kubernete...【详细内容】
2024-02-19  云云众生s  微信公众号  Tags:Kubernetes   点击:(43)  评论:(0)  加入收藏
SSL协议是什么?关于SSL和TLS的常见问题解答
SSL(安全套接字层)及其后继者TLS(传输层安全)是用于在联网计算机之间建立经过身份验证和加密的链接的协议。尽管SSL协议在 1999年已经随着TLS 1.0的发布而被弃用,但我们仍将这些...【详细内容】
2024-02-06  IDC点评网    Tags:SSL协议   点击:(74)  评论:(0)  加入收藏
从零开始了解网络协议:TCP/IP详解
从零开始了解网络协议:TCP/IP详解 在当今数字化的时代,网络协议已经成为我们生活中不可或缺的一部分。作为互联网的基础,网络协议规定了数据如何在不同的网络设备之间传输。TC...【详细内容】
2024-02-01    简易百科  Tags:TCP/IP   点击:(62)  评论:(0)  加入收藏
BGP路由属性:互联网路由的灵活控制器
在互联网的庞大网络中,边界网关协议(BGP)是确保不同自治系统(AS)间路由信息有效交换的关键协议。然而,BGP的功能远不止于此。其核心组成部分,即BGP路由属性,赋予了BGP强大的灵活性,使...【详细内容】
2024-01-26  诺诺爱生活    Tags:互联网路由   点击:(45)  评论:(0)  加入收藏
简易百科之什么是网络延迟?
简易百科之什么是网络延迟?随着互联网的普及和发展,网络已经成为我们生活中不可或缺的一部分。然而,我们在使用网络时可能会遇到一种情况,那就是网络延迟。那么,什么是网络延迟呢...【详细内容】
2024-01-24    简易百科  Tags:网络延迟   点击:(163)  评论:(0)  加入收藏
网络延迟与网络速度有什么区别?分享具体的答案
通常,许多人抱怨网速测试。速度还是不错的,但是他们玩游戏的时候怎么会卡住,还是断开连接等等问题,这一系列问题始终困扰着大家。那么,网络延迟与网络速度有什么区别呢?请不要担心...【详细内容】
2024-01-24  萌新小郭    Tags:网络延迟   点击:(54)  评论:(0)  加入收藏
揭秘IP地址的网络威胁与攻击类型
在当今数字化时代,网络攻击已经成为网络安全的一大挑战。IP地址,作为互联网通信的基础,也成为网络威胁和攻击的焦点之一。本文将深入探讨不同类型的网络威胁和攻击,以及如何防范...【详细内容】
2024-01-22  IP数据云    Tags:IP地址   点击:(88)  评论:(0)  加入收藏
站内最新
站内热门
站内头条