Linux&C语言简单实现抓包分析-Wireshark

Linux&C语言简单实现抓包分析-Wireshark,第1张

目录 一、数据交互1.Windows运行网络调试助手作为 TCP 服务器2.Ubuntu启动一个TCP客户端程序客户端---02client.c执行结果 二、抓包分析wireshark1.应用层---用户数据2.传输层---TCP协议转载: 3.网络层---IP协议路由器是根据ip地址来收发数据的,路由器是一个工作在网络层的设备 4.链路层---以太网(MAC)交换机是根据mac地址收发数据的,所以交换机是工作在链路层的设备 6. 非原创

一、数据交互 1.Windows运行网络调试助手作为 TCP 服务器

NetAssist网络调试助手

使用教程

2.Ubuntu启动一个TCP客户端程序 客户端—02client.c

02client.c

#include 

/*socket-bind-listen-accept*/
#include 
#include 
/*memset*/
#include 
/*sockaddr_in结构体*/
#include 
#include 
#include 
/*htons*/
#include 
/*inet_addr*/
#include 
#include 
#include 
/*close*/
#include 
/*exit*/
#include 

int main(int argc, char const *argv[])
{
    if (3!=argc)
    {
        printf("Use: %s   \n",argv[0]);
        exit(-1);
    }
    // 1.创建流式套接字
    // socket返回的文件描述符
    int sockfd = 0; // IPV4使用,//TCP
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
    {
        perror("socket error");
        exit(-1);
    }
    printf("sockfd=%d\n",sockfd);

    // 2.填充服务器的网络信息结构体
    struct sockaddr_in addr;
    //清空、填充0
    memset(&addr, 0, sizeof(addr));
    addr.sin_family = AF_INET; // IPV4
    //端口号  //将无符号2字节整型  主机-->网络
    addr.sin_port = htons(atoi(argv[2]));
    // ip地址 //将strptr所指的字符串转换成32位的网络字节序二进制值。
    addr.sin_addr.s_addr = inet_addr(argv[1]);

    //结构体长度
    socklen_t addr_len = sizeof(addr);

    //3.与服务器建立连接 connect
                              //强制类型转换
    if(-1 == connect(sockfd, (struct sockaddr *)&addr, addr_len)){
		perror("connect error");
		exit(-1);
	}
    while (1)
    {
        char bu[128] = {0};
        //发
        printf("input  > ");
        scanf("%s", bu);
        send(sockfd, bu, 128,0);
        if (strcmp(bu,"quit")==0)
        {
            //关闭文件描述符
            close(sockfd);
            break;
        }

        //收
        memset(bu, 0, sizeof(bu));
        printf("服务器 > ");
        fflush(stdout);
	    recv(sockfd, bu, 128,0);
        printf("%s\n", bu);
        if (strcmp(bu,"quit")==0)
        {
            //关闭文件描述符
            close(sockfd);
            break;
        }
    
    }
    
   
    //关闭文件描述符
    close(sockfd);
   
    return 0;
}
执行结果


二、抓包分析 wireshark Windows安装Linux安装

linux 启动软件:

sudo wireshark使用教程 1.应用层—用户数据

2.传输层—TCP协议

转载:

Wireshark图解TCP三次握手与四次挥手


3.网络层—IP协议 路由器是根据ip地址来收发数据的,路由器是一个工作在网络层的设备

4.链路层—以太网(MAC) 交换机是根据mac地址收发数据的,所以交换机是工作在链路层的设备

6. 非原创

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/927149.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-17
下一篇 2022-05-17

发表评论

登录后才能评论

评论列表(0条)

保存