linux网络编程-网络分析测试工具、封包、IP和TCP头

抓包工具wireshark

 

 聊天程序原理

 wireshark工作原理

 

常用调试测试工具

使用telnet测试TCP服务器端
使用lsof
使用tcpdump
使用netstat
使用sniffer
使用wireshark
Chariot

SmartBit—硬件

TCP/IP协议网络封包格式

以太网头

 

IP头

 

 UDP头 

TCP头

 

TCP 的可靠传输:通过确认和重发机制


2.1.TCP 把所有要发送的数据进行编号(每一个字节用一个号)
2.2.发送时从当前数据位置,发送 window 大小的数据 

 

面向连接:TCP握手过程

 

TCP三次握手,四次挥手 

 三次、四次握手注意点:
1.一定标注客户端和服务器
2.三次握手的连接必须是由客户端发起 (四次握手客户端和服务器都可以发起)
3. SYN,,ACK, FIN 等标志符号应该写上|

网络信息检索、网络属性设置、超时检查 

网络信息检索函数

gethostname() 获得主机名
getpeername() 获得与套接口相连的远程协议地址
getsockname() 获得本地套接口协议地址
gethostbyname() 根据主机名取得主机信息 endhostent()

gethostbyaddr() 根据主机地址取得主机信息
getprotobyname() 根据协议名取得主机协议信息
getprotobynumber() 根据协议号取得主机协议信息
getservbyname() 根据服务名取得相关服务信息
getservbyport() 根据端口号取得相关服务信息

域名解析步骤:

1、添加#include <netdb.h>头文件

2、定义结构体变量hs,    struct hostent* hs = NULL;

3、通过gethostbyname域名解析,将域名转换为IP地址

4、将取到服务器的32位整数IP地址

	//将转化后的ip值赋值给服务器结构体变量
	sin.sin_addr.s_addr = *(uint32_t*)hs->h_addr;
	endhostent();//释放掉结构体变量
	hs = NULL;

 

 

说明:
IPv4 中使用 gethostbyname() 函数完成主机名到地址解析,这个函数仅仅支持 IPv4,且不允许调用者指定所需地址类型的任何信息,返回的结构只包含了用于存储 IPv4 地址的空间。IPv6 中引入了 getaddrinfo()的新 API,它是协议无关的,既可用于 IPv4 也可用于 IPv6。 

网络属性设置

getsockopt和setsockopt 

int getsockopt(int sockfd,int level,int optname,void *optval,socklen_t *optlen)
int setsockopt(int sockfd,int level,int optname,const void *optval,socklen_t *optlen)

level指定控制套接字的层次.可以取三种值:

1)SOL_SOCKET:通用套接字选项.(应用层)

2)IPPROTO_IP:IP选项.(传输层)

3)IPPROTO_TCP:TCP选项. (网络层)

optname指定控制的方式(选项的名称),我们下面详细解释 

optval获得或者是设置套接字选项.根据选项名称的数据类型进行转换 

 

 

	/* 允许广播 */
	int b_br = 1;
	setsockopt (fd, SOL_SOCKET, SO_BROADCAST, &b_br, sizeof (int));

	/* 设置接收超时 */
	struct timeval tout;
	tout.tv_sec = 5;
	tout.tv_usec = 0;
	setsockopt (fd, SOL_SOCKET, SO_RCVTIMEO, &tout, sizeof (struct timeval));

网络超时

在网络通信中,很多操作会使得进程阻塞

TCP套接字中的recv/accept/connect

UDP套接字中的recvfrom

超时检测的必要性
避免进程在没有数据时无限制地阻塞
当设定的时间到时,进程从原操作返回继续运行

网络超时检测(一)

设置socket的属性 SO_RCVTIMEO

参考代码如下

    struct timeval  tv;

     tv.tv_sec = 5;   //  设置5秒时间
     tv.tv_usec = 0;

     setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO,  &tv,  
                       sizeof(tv));   //  设置接收超时
      recv() / recvfrom()    //   从socket读取数据

 网络超时检测(二)

用select检测socket是否’ready’

参考代码如下

while(1)
{
    struct fd_set rdfs;
    struct timeval  tv = {5 , 0};   // 设置5秒时间

    FD_ZERO(&rdfs);
    FD_SET(sockfd, &rdfs);

    if (select(sockfd+1, &rdfs, NULL, NULL, &tv) > 0)   // socket就绪
    {
          recv() /  recvfrom()    //  从socket读取数据
    }
}

网络超时检测(三)

设置定时器(timer),

捕捉SIGALRM信号 参考代码如下

    void  handler(int signo)     {   return;  }

      struct sigaction  act;
      sigaction(SIGALRM, NULL, &act);
      act.sa_handler = handler;
      act.sa_flags &= ~SA_RESTART;//清除掉 SIGALRM 信号的 SA_RESTART
      sigaction(SIGALRM, &act, NULL);
      alarm(5);
      if (recv(,,,) < 0) ……

      思考:
  试总结如何在linux中动态检查到是否有网络以及网络中途的掉线/连接的检查?
  提示: 
    1.应用层
        心跳检测
2.内核中

 网卡驱动中 2.6内核里面,使能1s的周期性检查定时器
 网卡硬件或者我们通过GPIO,插拔网线时候产生中断,处理相应中断 //立即检测到

 心跳监测

 方法1: 数据交互双方隔一段时间,一方发送一点数据到对方,对方给出特定的应答。如超过设定次数大小的时间内还是没有应答,这时候认为异常

方法 2:改变套接字的属性来实现

void setKeepAlive (int sockfd, int attr_on, socklen_t idle_time, socklen_t interval, socklen_t cnt)
{

	setsockopt (sockfd, SOL_SOCKET, SO_KEEPALIVE, (const char *) &attr_on, sizeof (attr_on));
	setsockopt (sockfd, SOL_TCP, TCP_KEEPIDLE, (const char *) &idle_time, sizeof (idle_time));
	setsockopt (sockfd, SOL_TCP, TCP_KEEPINTVL, (const char *) &interval, sizeof (interval));
	setsockopt (sockfd, SOL_TCP, TCP_KEEPCNT, (const char *) &cnt, sizeof (cnt));
}

	int keepAlive = 1;			//设定KeepAlive
	int keepIdle = 5;			//开始首次KeepAlive探测前的TCP空闭时间
	int keepInterval = 5;		//两次KeepAlive探测间的时间间隔
	int keepCount = 3;			//判定断开前的KeepAlive探测次数

	setKeepAlive (newfd, keepAlive, keepIdle, keepInterval, keepCount);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Wireshark(前称 Ethereal)是一个软件开发人员经常用到的网络封包分析软件。Wireshark 中文版网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。当然网站上也有其它的网络抓包工具也非常好用,比如 Fiddler 汉化版等等。 网络封包分析工具 Wireshark Portable 中文多语特别版 网络封包分析工具 Wireshark Portable 中文多语特别版 Wireshark 中文便携版使用 WinPCAP 作为接口,直接与网卡进行数据报文交换。网络封包分析软件的功能可想像成 “电工技师使用电表来量测电流、电压、电阻” 的工作 – 只是将场景移植到网络上,并将电线替换成网络线。 在过去,网络封包分析软件 Wireshark 非常昂贵,或是专门属于营利用的软件。Ethereal 的出现改变了这一切。在 GNUGPL 通用许可证的保障范围底下,使用者可以以免费的代价取得软件与其源代码,并拥有针对其源代码修改及客制化的权利。Ethereal是目前全世界最广泛的网络封包分析软件之一。 Wireshark 中文版是世界上最流行的网络分析工具。这个强大的工具可以捕捉网络中的数据,并为用户提供关于网络和上层协议的各种信息。与很多其他网络工具一样,Wireshark 也使用 pcap network library 来进行封包捕捉。可免费局域网内QQ、邮箱、msn、账号等的密码! Wireshark 中文版的原名是 Ethereal,新名字是 2006 年起用的。当时 Ethereal 的主要开发者决定离开他原来供职的公司,并继续开发这个软件。但由于 Ethereal 这个名称的使用权已经被原来那个公司注册,Wireshark 这个新名字也就应运而生了。 在成功运行 Wireshark 之后,我们就可以进入下一步,更进一步了解这个强大的工具。 Wireshark 使用目的 网络管理员使用 Wireshark 来检测网络问题,网络安全工程师使用 Wireshark 来检查资讯安全相关问题,开发者使用 Wireshark 来为新的通讯协定除错,普通使用者使用 Wireshark 来学习网络协定的相关知识。当然,有的人也会“居心叵测”的用它来寻找一些敏感信息&hellip;&hellip; Wireshark 不是入侵侦测系统(Intrusion Detection System,IDS)。对于网络上的异常流量行为,Wireshark 不会产生警示或是任何提示。然而,仔细分析 Wireshark 撷取的封包能够帮助使用者对于网络行为有更清楚的了解。Wireshark 不会对网络封包产生内容的修改,它只会反映出目前流通的封包资讯。 Wireshark本身也不会送出封包网络上。 Wireshark 使用教程 1.确定 Wireshark 的位置 如果没有一个正确的位置,启动Wireshark后会花费很长的时间捕获一些与自己无关的数据。 2.选择捕获接口 一般都是选择连接到Internet网络的接口,这样才可以捕获到与网络相关的数据。否则,捕获到的其它数据对自己也没有任何帮助。 3.使用捕获过滤器 通过设置捕获过滤器,可以避免产生过大的捕获文件。这样用户在分析数据时,也不会受其它数据干扰。而且,还可以为用户节约大量的时间。 4.使用显示过滤器 通常使用捕获过滤器过滤后的数据,往往还是很复杂。为了使过滤的数据包再更细致,此时使用显示过滤器进行过滤。 5.使用着色规则 通常使用显示过滤器过滤后的数据,都是有用的数据包。如果想更加突出的显示某个会话,可以使用着色规则高亮显示。 6.构建图表 如果用户想要更明显的看出一个网络中数据的变化情况,使用图表的形式可以很方便的展现数据分布情况。 7.重组数据 Wireshark 的重组功能,可以重组一个会话中不同数据包的信息,或者是一个重组一个完整的图片或文件。由于传输的文件往往较大,所以信息分布在多个数据包中。为了能够查看到整个图片或文件,这时候就需要使用重组数据的方法来实现。
### 回答1: 易语言是一种可视化编程语言,用于开发Windows平台的应用程序。封包解包工具是指用于将数据进行打包和拆包的工具,主要用于网络编程中数据的传输和通信。 易语言中有一些第三方库和插件可以用于实现TCP封包解包的功能。这些库和插件提供了一些函数和方法,方便开发人员在易语言中进行数据的封包和解包。 TCP封包是将数据按照一定的格式进行打包,以便于在网络上进行传输。常用的封包格式有固定长度封包、变长封包和自定义格式封包等。使用易语言进行TCP封包时,可以使用这些第三方库和插件中提供的函数,按照指定的封包格式将数据进行打包。 TCP解包是将封包后的数据拆分成可识别的数据。解包操作与封包相反,通过读取封包中的长度字段和标识字段等信息,将封包还原为原始数据。易语言中的TCP解包工具可以根据封包格式的规则进行解包操作,并将解包后的数据返回给开发人员使用。 使用易语言进行TCP封包解包的工具可以帮助开发人员简化数据传输的过程,提高开发效率和数据传输的安全性。通过这些工具,开发人员可以方便地进行数据的封包和解包操作,从而更好地实现网络通信功能。 ### 回答2: 易语言是一种编程语言,它可以用于开发Windows系统下的应用程序。TCP封包解包工具是易语言提供的一个工具,用于处理TCP协议传输的数据包。 在网络通信中,数据的传输是以数据包的形式进行的。TCP封包解包工具可以帮助程序员处理从网络接收到的数据包,以及将要发送的数据转换为合适的格式进行传输。 封包指的是将数据转换为特定格式的过程。TCP封包解包工具可以将数据按照协议要求的格式进行封装,例如添加报文部、计算校验和等操作,以便正确地发送给对方。 解包指的是将接收到的数据包进行解析的过程。TCP封包解包工具可以按照协议规定的格式解析数据包,并提取出其中的有效信息,以便程序能够正确地处理这些数据。 TCP封包解包工具可以帮助程序员简化网络通信的开发过程,使得开发人员能够更加专注于实现业务逻辑。它提供了一套封包解包的接口和函数库,开发者只需要调用相应的函数来完成数据的封包和解包操作即可。 总之,易语言TCP封包解包工具是易语言提供的一个工具,用于处理TCP协议传输的数据包,使开发者能够更加方便地进行网络通信的开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值