首页 > 其他 > 详细

TCP怎么保证传输的安全性

时间:2020-05-07 19:55:32      阅读:90      评论:0      收藏:0      [点我收藏+]

我们都知道TCP是面向连接的可靠传输协议,保证数据的传输安全、顺序准确性及数据可达性。
那么保证这些安全的原理或是机制到底是什么呢?

接下来称TCP的发送方为A,接收方为B
TCP保证可靠性的两个协议:

1. 停止等待协议
每发送完一个分组,就停止发送,等待对方确认,收到确认后再发送下一个分组。
出现差错的情况:
(1)A在发送之后设置一个定时器,若超过定时器时间还没有收到确认,就重新发送次分组(A发送的分组必须要留一个副本,为超时重传所用)。如果B检测收到的分组有错,就丢弃分组,什么也不做(TCP将保持它首部和数据的检验和CRC。这个检验和目的是检测数据在传输过程中的任何变化)。当发现在超过计时器时间还未收到确认信号,则采用超时重传功能重新发送。

技术分享图片

 

 

(2)确认丢失:如果B发送的确认信号丢失后,A定时器超出时间,则重新发送这个分组,B丢弃这个分组,不向上层交付,同时向A重新发送确认。

技术分享图片

 

 (3)确认迟到:

技术分享图片

 

 

流程图如上所示,A收到这个迟到的确认后会丢弃这个确认,什么都不做。

至此,就是停止等待协议中会出现的问题。而一一解决这些问题的重传机制,就是ARQ(自动重传请求)协议,也就是重传的请求是自动的,不需要B请求A发送某一个丢失或者出错的数据。
很显然,这种方式信道利用率很低,这个时候我们就采用连续ARQ协议。

2. 连续ARQ协议
利用滑动窗口,位于滑动窗口内的所有分组都可以连续的发送出去,而不需要逐个等待对方的确认。A每收到一个确认,就把发送窗口向前滑动一个分组的位置。B采用累积确认的方式,对按序到达的最后一个分组发送确认(就是最后这个分组的编号),就表示这个分组之前的所有分组都收到了。
(1)优点:信道利用率高,容易实现,即使确认丢失,也不必重传。
(2) 缺点:不能向发送方反映出接收方已经正确收到的所有分组的信息。
比如:发送方发送了5条消息,中间第三条丢失(3号),这时接收方只能对前两个发送确认。发送方无法知道后三个分组的下落,而只好把后三个全部重传一次。这也叫
Go-Back-N(回退N),表示需要退回来重传已经发送过的N个消息。

保证数据的顺序性:
TCP报文段作为IP数据来进行传输,而IP数据报的到达可能会失序,因此TCP到达也可能会失序,所以如果有必要,TCP将对收到的数据进行重新排序,将收到的数据以正确的顺序交给应用层。

 

转载自:https://www.pianshen.com/article/1585300388/

TCP怎么保证传输的安全性

原文:https://www.cnblogs.com/sunlong88/p/12845035.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!