UDO TCP IP ICMP

2024-01-16 09:30
文章标签 ip icmp tcp udo

本文主要是介绍UDO TCP IP ICMP,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、UDP协议
UDP协议是建立在IP协议基础之上的,用在传输层的协议。UDP和IP协议一样是不可靠的数据报服务。
0                               16                              32 
------------------------------------------------------- 
|       UDP源端口     |      UDP目的端口   | 
-------------------------------------------------------
|   UDP数据报长度 |   UDP数据报校验 | 
-------------------------------------------------------
|                              数据                             | 
-------------------------------------------------------

UDP的头格式为: 
struct udphdr
{
u_int16_t source; /*源地址端口*/
u_int16_t dest;    /*目的地址端口*/
u_int16_t len;     /*UDP长度*/
u_int16_t check;   /*UDP校验和*/
}; 
头文件:linux/udp.h

2、ICMP协议
ICMP是消息控制协议,也处于网络层。在网络上传递IP数据包时,如果发生了错误,那么就会用ICMP协议来报告错误。 
0               8             16                        32 
----------------------------------------------------
|    类型    |    代码    |       校验和           | 
----------------------------------------------------
|        识别号           |     报文序列号      | 
----------------------------------------------------
ICMP的头格式为: 
struct icmphdr 

u_int8_t type;                /* 类型 */ 
u_int8_t code;                /* 代码*/ 
u_int16_t checksum;   /*校验和*/
union 

    struct 
    { 
      u_int16_t id; 
      u_int16_t sequence; 
    } echo;                     /* echo datagram */ 
    u_int32_t   gateway;        /* gateway address */ 
    struct 
    { 
      u_int16_t __unused; 
      u_int16_t mtu; 
    } frag;                     /* path mtu discovery */ 
} un; 
};
头文件:linux /icmp.h

3、IP协议
IP协议是在网络层的协议,它主要完成数据包的发送作用,下面这个表是IPv4的数据包格式:  

IP的头格式为:

struct iphdr {
#if defined(__LITTLE_ENDIAN_BITFIELD) /*小端*/
    __u8 ihl:4,              /*IP头部长度*/
          version:4;              /*IP版本,值为4*/
#elif defined (__BIG_ENDIAN_BITFIELD)/*大端*/
    __u8 version:4,          /*IP版本,值为4*/
                 ihl:4;              /*IP头部长度*/
#else
#error "Please fix <asm/byteorder.h>"
#endif
    __u8    tos;                /*服务类型*/
    __be16 tot_len;            /*总长度*/
    __be16 id;                 /*标识*/
    __be16 frag_off;           /*片偏移*/
    __u8    ttl;                /*生存时间*/
    __u8    protocol;           /*协议类型*/
    __u16   check;              /*头部校验和*/
    __be32 saddr;              /*源IP地址*/
    __be32 daddr;              /*目的IP地址*/
      /*IP选项*/
};
头文件:linux/ip.h

4、TCP协议


TCP的头格式为:
struct tcphdr 
{
    __u16   source;         /*源地址端口*/
    __u16   dest;           /*目的地址端口*/
    __u32   seq;            /*序列号*/
    __u32   ack_seq;        /*确认序列号*/
#if defined(__LITTLE_ENDIAN_BITFIELD)
    __u16 res1:4,         /*保留*/
         doff:4,            /*偏移*/
        fin:1,              /*关闭连接标志*/
        syn:1,              /*请求连接标志*/
        rst:1,              /*重置连接标志*/
        psh:1,              /*接收方尽快将数据放到应用层标志*/
        ack:1,              /*确认序号标志*/
        urg:1,              /*紧急指针标志*/
        ece:1,              /*拥塞标志位*/
        cwr:1;              /*拥塞标志位*/
#elif defined(__BIG_ENDIAN_BITFIELD)
    __u16 doff:4,         /*偏移*/
        res1:4,             /*保留*/
        cwr:1,              /*拥塞标志位*/
        ece:1,              /*拥塞标志位*/
        urg:1,              /*紧急指针标志*/
        ack:1,              /*确认序号标志*/
        psh:1,              /*接收方尽快将数据放到应用层标志*/
        rst:1,              /*重置连接标志*/
        syn:1,              /*请求连接标志*/
        fin:1;              /*关闭连接标志*/
#else
#error "Adjust your <asm/byteorder.h> defines"
#endif 
    __u16   window;         /*滑动窗口大小*/
    __u16   check;          /*校验和*/
    __u16   urg_ptr;        /*紧急字段指针*/
};
头文件:linux/tcp.h

tcphdr->source
    16位源端口号
tcphdr->dest
    16位目的端口号
tcphdr->seq
    表示此次发送的数据在整个报文段中的起始字节数。序号是32 bit的无符号数。为了安全起见,它的初始值是一个随机生成的数,它到达32位最大值后,又从零开始。
tcphdr->ack_seq
    指定的是下一个期望接收的字节,而不是已经正确接收到的最后一个字节。
tcphdr->doff
    TCP头长度,指明了在TCP头部包含多少个32位的字。此信息是必须的,因为options域的长度是可变的,所以整个TCP头部的长度也是变化的。从技术上讲,这个域实际上��明了数据部分在段内部的其起始地址(以32位字作为单位进行计量),因为这个数值正好是按字为单位的TCP头部的长度,所以,二者的效果是等同的
tcphdr->res1为保留位
tcphdr->window
    是16位滑动窗口的大小,单位为字节,起始于确认序列号字段指明的值,这个值是接收端正期望接收的字节数,其最大值是63353字节。
    TCP中的流量控制是通过一个可变大小的滑动窗口来完成的。window域指定了从被确认的字节算起可以接收的多少个字节。window = 0也是合法的,这相当于说,到现在为止多达ack_seq-1个字节已经接收到了,但是接收方现在状态不佳,需要休息一下,等一会儿再继续接收更多的数据,谢谢。以后,接收方可以通过发送一个同样ack_seq但是window不为0的数据段,告诉发送方继续发送数据段。
tcphdr->check
    是检验和,覆盖了整个的TCP报文段,这是一个强制性的字段,一定是由发送端计算和存储,并由接收端进行验证。
tcphdr->urg_ptr
    这个域被用来指示紧急数据在当前数据段中的位置,它是一个相对于当前序列号的字节偏移值。这个设施可以代替中断信息。 
fin, syn, rst, psh, ack, urg为6个标志位
    这6个位域已经保留了超过四分之一个世纪的时间而仍然原封未动,这样的事实正好也说明了TCP的设计者们考虑的是多么的周到。它们的含义如下:
    tcphdr->fin fin位被用于释放一个连接。它表示发送方已经没有数据要传输了。
    tcphdr->syn 同步序号,用来发起一个连接。syn位被用于建立连接的过程。在连接请求中,syn=1; ack=0表示该数据段没有使用捎带的确认域。连接应答捎带了一个确认,所以有syn=1; ack=1。本质上,syn位被用来表示connection request和connection accepted,然而进一步用ack位来区分这两种情况。 
    tcphdr->rst 该为用于重置一个已经混乱的连接,之所以会混乱,可能是由于主机崩溃,或者其他的原因。该位也可以被用来拒绝一个无效的数据段,或者拒绝一个连接请求。一般而言,如果你得到的数据段设置了rst位,那说明你这一端有了问题。 
    tcphdr->psh 接收方在收到数据后应立即请求将数据递交给应用程序,而不是将它缓冲起来直到整个缓冲区接收满为止(这样做的目的可能是为了效率的原因) 
    tcphdr->ack ack位被设置为1表示tcphdr->ack_seq是有效的。如果ack为0,则该数据段不包含确认信息,所以,tcphdr->ack_seq域应该被忽略。 
    tcphdr->urg 紧急指针有效 
    tcphdr->ece 用途暂时不明
    tcphdr->cwr 用途暂时不明

对于TCP协议,其IP头部的protocol的值应该为6,通过计算IP头部的长度可以得到TCP头部的地址,即TCP的头部在IP头部长度ihl*4之后。

这篇关于UDO TCP IP ICMP的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/612094

相关文章

【Go】go连接clickhouse使用TCP协议

离开你是傻是对是错 是看破是软弱 这结果是爱是恨或者是什么 如果是种解脱 怎么会还有眷恋在我心窝 那么爱你为什么                      🎵 黄品源/莫文蔚《那么爱你为什么》 package mainimport ("context""fmt""log""time""github.com/ClickHouse/clickhouse-go/v2")func main(

2024.9.8 TCP/IP协议学习笔记

1.所谓的层就是数据交换的深度,电脑点对点就是单层,物理层,加上集线器还是物理层,加上交换机就变成链路层了,有地址表,路由器就到了第三层网络层,每个端口都有一个mac地址 2.A 给 C 发数据包,怎么知道是否要通过路由器转发呢?答案:子网 3.将源 IP 与目的 IP 分别同这个子网掩码进行与运算****,相等则是在一个子网,不相等就是在不同子网 4.A 如何知道,哪个设备是路由器?答案:在 A

图解TCP三次握手|深度解析|为什么是三次

写在前面 这篇文章我们来讲解析 TCP三次握手。 TCP 报文段 传输控制块TCB:存储了每一个连接中的一些重要信息。比如TCP连接表,指向发送和接收缓冲的指针,指向重传队列的指针,当前的发送和接收序列等等。 我们再来看一下TCP报文段的组成结构 TCP 三次握手 过程 假设有一台客户端,B有一台服务器。最初两端的TCP进程都是处于CLOSED关闭状态,客户端A打开链接,服务器端

网络原理之TCP协议(万字详解!!!)

目录 前言 TCP协议段格式 TCP协议相关特性 1.确认应答 2.超时重传 3.连接管理(三次握手、四次挥手) 三次握手(建立TCP连接) 四次挥手(断开连接)  4.滑动窗口 5.流量控制 6.拥塞控制 7.延迟应答 8.捎带应答  9.基于字节流 10.异常情况的处理 小结  前言 在前面,我们已经讲解了有关UDP协议的相关知识,但是在传输层,还有

linux下查看自己的外网ip

局域网的服务器是通过ADSL路由器连接外网的,但ADSL是从ISP运营商那儿通过动态获得IP的,那么我怎么知道自己的外网地址是多少呢? 今天得到几个办法: curl -s http://whatismyip.org wget http://whatismyip.org 然后再  cat index.html 也可以看到

linux下TCP/IP实现简单聊天程序

可以在同一台电脑上运行,在一个终端上运行服务器端,在一个终端上运行客户端。 服务器端的IP地址要和本地的IP相同,并分配端口号,客户端的默认设置为本地,端口号自动分配。 服务器端: #include <stdio.h>#include <stdlib.h>#include <errno.h>#include <string.h>#include <sys/types.

超越IP-Adapter!阿里提出UniPortrait,可通过文本定制生成高保真的单人或多人图像。

阿里提出UniPortrait,能根据用户提供的文本描述,快速生成既忠实于原图又能灵活调整的个性化人像,用户甚至可以通过简单的句子来描述多个不同的人物,而不需要一一指定每个人的位置。这种设计大大简化了用户的操作,提升了个性化生成的效率和效果。 UniPortrait以统一的方式定制单 ID 和多 ID 图像,提供高保真身份保存、广泛的面部可编辑性、自由格式的文本描述,并且无需预先确定的布局。

C# 如何同时Ping多个IP地址

在C#中,如果需要同时ping多个IP地址,可以采用多线程或异步编程的方式来实现,以便可以同时进行多个ping操作。以下是两种常用的方法: 方法一:使用多线程(Task 或 Thread) 使用Task是更现代和推荐的方式,因为它内置了更好的线程管理和异常处理机制。以下是一个使用Task的示例,展示如何同时ping多个IP地址: using System; using System.Co

JAVAEE初阶第七节(中)——物理原理与TCP_IP

系列文章目录 JAVAEE初阶第七节(中)——物理原理与TCP_IP 文章目录 系列文章目录JAVAEE初阶第七节(中)——物理原理与TCP_IP 一.应用层重点协议)1. DNS2 .NAT3. NAT IP转换过程 4 .NAPT5. NAT技术的缺陷6. HTTP/HTTPS7. 自定义协议 二. 传输层重点协议 1 .UDP协议 2.1.1 UDP协议端格式 2.1.2 UD

一台电脑对应一个IP地址吗?‌探讨两台电脑共用IP的可能性

在当今数字化时代,‌IP地址作为网络世界中的“门牌号”,‌扮演着至关重要的角色。‌它负责在网络上唯一标识每一台设备,‌使得数据能够在庞大的互联网中准确无误地传输。‌然而,‌对于IP地址与电脑之间的对应关系,‌许多人可能存有疑惑:‌一台电脑是否必须对应一个IP地址?‌两台电脑又是否可以共用一个IP地址呢?‌本文将深入探讨这些问题,‌带您一窥IP地址背后的奥秘。‌ 一台电脑对应一个IP地址吗?‌