网络扫盲:Tcp协议和hettp、https协议、三次握手四次挥手

HTTP(Hypertext Transfer Protocol)

是一种用于传输超文本的协议,是Web应用程序的基础。HTTP协议使用客户端-服务器模型,客户端发出请求,服务器返回响应。HTTP协议是无状态的,即服务器不会记住之前的请求和响应,每个请求和响应都是独立的。HTTP协议使用TCP作为传输协议,通常使用80端口。

HTTP协议的应用场景非常广泛,例如:

1. 浏览器访问网页:浏览器向服务器发送HTTP请求,服务器返回HTML文件作为响应,浏览器解析HTML文件并显示网页。

2. 上传文件:客户端向服务器发送HTTP请求,请求上传文件,服务器返回响应,客户端把文件分块上传。

3. Web API:客户端向服务器发送HTTP请求,请求获取数据,服务器返回响应,客户端解析响应并显示数据。

示例:

当我们在浏览器中输入网址,如https://www.baidu.com,浏览器会向服务器发送HTTP请求,请求返回百度的主页。服务器接收到请求后,返回HTML文件作为响应,浏览器解析HTML文件并显示网页。

HTTP和HTTPS协议的主要区别在于安全性和加密方式。

HTTP协议是明文传输的,即数据在传输过程中不加密,容易被黑客窃听、篡改和伪造。而HTTPS协议使用SSL/TLS协议对数据进行加密,可以保证数据的安全性,防止被黑客窃听、篡改和伪造。

HTTP协议使用80端口进行传输,而HTTPS协议使用443端口进行传输。

在使用HTTP协议时,数据传输速度较快,但安全性较差;在使用HTTPS协议时,数据传输速度较慢,但安全性较好。

因此,对于一些需要保密性和安全性的数据传输,建议使用HTTPS协议。

举个例子,当我们在浏览器中输入网址 https://www.taobao.com 时,浏览器会向淘宝服务器发送HTTPS请求,服务器返回加密后的响应,浏览器解密响应并显示网页。

SSL(Secure Socket Layer)和TLS(Transport Layer Security)协议

是用于保证网络通信安全的协议,TLS是SSL的继任者。SSL/TLS协议使用非对称加密和对称加密相结合的方式,来确保数据传输的安全性和完整性。

SSL/TLS协议的应用场景非常广泛,例如:

1. 网络安全:SSL/TLS协议可以用于保护网站、电子邮件、即时通讯等网络应用程序的安全。

2. 电子商务:SSL/TLS协议可以用于保护在线支付、网上银行等电子商务交易的安全。

3. 远程访问:SSL/TLS协议可以用于保护远程访问、VPN等网络连接的安全。

SSL/TLS协议的实现方式如下:

1. 握手阶段:客户端向服务器发送一个初始请求,请求建立SSL/TLS连接。服务器返回证书和公钥,客户端使用公钥加密一个随机数并发送给服务器。服务器使用私钥解密随机数,同时使用该随机数生成一个会话密钥。

2. 认证阶段:服务器验证客户端证书的有效性,如果证书有效,则继续下一步;否则,SSL/TLS连接将被终止。

3. 密钥交换阶段:客户端和服务器使用会话密钥加密和解密数据,保证数据传输的安全性和完整性。

SSL/TLS协议的实现需要使用数字证书,数字证书是由第三方机构颁发的,用于验证网站的身份和安全性。数字证书包含网站的公钥、网站的名称、证书颁发机构的名称等信息。

举个例子,当我们在浏览器中访问一个使用SSL/TLS协议保护的网站时,浏览器会先与网站建立SSL/TLS连接,然后使用会话密钥加密和解密数据,保证数据传输的安全性和完整性。

第三方机构

第三方机构一般指的是数字证书认证机构(CA,Certificate Authority),也称证书颁发机构。数字证书认证机构是一种可信任的第三方机构,用于验证网站或个人的身份和安全性,并颁发数字证书。

数字证书认证机构通常是一些大型的国际或国内机构,如Symantec、Comodo、GlobalSign、Let's Encrypt等。这些机构会对网站的身份和信息进行认证,确保网站是真实存在的、合法经营的,并且具有一定的安全性保障措施。同时,数字证书认证机构也会对颁发的数字证书进行管理和监督,确保数字证书的有效性和安全性。

当用户在访问一个使用SSL/TLS协议保护的网站时,浏览器会自动从数字证书认证机构获取网站的数字证书,并验证其有效性。如果数字证书有效,则浏览器会显示一个绿色的锁形图标,表示网站是安全的。如果数字证书无效,则浏览器会显示一个警告提示,建议用户不要访问该网站。

三次握手和四次挥手是TCP协议中用于建立和断开连接的过程。

三次握手指的是在建立TCP连接时,客户端和服务器之间需要进行三次交互的过程。具体过程如下:

1. 客户端向服务器发送一个SYN(同步)请求,表示客户端要建立连接。

2. 服务器收到客户端的SYN请求后,向客户端发送一个SYN-ACK(同步-确认)响应,表示服务器已经收到客户端的请求,并准备好建立连接。

3. 客户端收到服务器的SYN-ACK响应后,再向服务器发送一个ACK(确认)请求,表示客户端已经收到服务器的响应,并准备好建立连接。

这样,客户端和服务器之间就建立了一条TCP连接。

四次挥手指的是在断开TCP连接时,客户端和服务器之间需要进行四次交互的过程。具体过程如下:

1. 客户端向服务器发送一个FIN(结束)请求,表示客户端要断开连接。

2. 服务器收到客户端的FIN请求后,向客户端发送一个ACK响应,表示服务器已经收到客户端的请求,并准备好断开连接。

3. 服务器向客户端发送一个FIN请求,表示服务器也要断开连接。

4. 客户端收到服务器的FIN请求后,向服务器发送一个ACK响应,表示客户端已经收到服务器的请求,并准备好断开连接。

这样,客户端和服务器之间的TCP连接就断开了。

三次握手和四次挥手是TCP协议中非常重要的过程,它们保证了数据传输的可靠性和完整性,防止了数据的重复传输和丢失。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值