udp测试

目录

 

简易测试

1,UDP 的小程序

2,UDP数据报文


简易测试

1,UDP 的小程序

我自己写了一个UDP 的小程序,有一个UDP 的server,而且有UDP的client。

      然后执行server和client,然后用tcpdump将该端口的UDP数据报文抓取出来。

      执行的过程是这样的。

      client向server发送"xiyou"

     server向client应答"wangzhe"

      client程序在主机example上运行(192.168.0.18)

      server程序在主机linux上运行(192.168.0.9)

 

2,UDP数据报文

linux@linux:~$ sudo tcpdump -vvv -X  udp port 7777
[sudo] password for linux: 
tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes
11:03:01.923227 IP (tos 0x0, ttl 64, id 0, offset 0, flags [DF], proto UDP (17), length 48)
    example.local.43521 > linux.7777: [udp sum ok] UDP, length 20
	0x0000:  4500 0030 0000 4000 4011 b677 c0a8 0190  E..0..@.@..w....
	0x0010:  c0a8 0165 aa01 1e61 001c 4c34 7869 796f  ...e...a..L4xiyo
	0x0020:  7500 0000 0000 0000 0000 0000 0000 0000  u...............
11:03:01.923343 IP (tos 0x0, ttl 64, id 0, offset 0, flags [DF], proto UDP (17), length 48)
    linux.7777 > example.local.43521: [bad udp cksum 6869!] UDP, length 20
	0x0000:  4500 0030 0000 4000 4011 b677 c0a8 0165  E..0..@.@..w...e
	0x0010:  c0a8 0190 1e61 aa01 001c 8473 7761 6e67  .....a.....swang
	0x0020:  7a68 6500 0000 0000 0000 0000 0000 0000  zhe.............

由上面的报文可知,有两个UDP数据报文。

第一个报文是example主机上的client向server发送数据。

4500 0030 0000 4000 4011 b677 c0a8 0190 c0a8 0165 这20个数据是IP首部。

aa01 1e61 001c 4c34 这8个字节是UDP的首部。

7869 796f 7500 0000 0000 0000 0000 0000 0000 0000 这20个数据是我用sendto函数发送的

数据。

 

而将char req[20] = "xiyou" 的ASCII码(16进制)就是:

78 69 79 6f 75 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

 

第二个报文是linux向主机example做出的应答。

4500 0030 0000 4000 4011 b677 c0a8 0165 c0a8 0190 这20个数据是IP首部。

1e61 aa01 001c 8473 这8个字节是UDP首部。

7761 6e67 7a68 6500 0000 0000 0000 0000 0000 0000 这20个数据是应用层的数据。

 

而将char reply[20] = "wangzhe"的ASCII码(16进制)就是:

77 61 6e 67 7a 68 65 0 0 0 0 0 0 0 0 0 0 0 0 0

 

由此看出,应用层的数据没有夹杂其他的参数,全部是数据,均是字符的ASCII码。

udp_server.c

#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <sys/types.h>
#include <string.h>

int main(void)
{
        struct sockaddr_in server,client;
        int sockfd;
        int cli_len = 0,n;
        char req[20] = {0},reply[20] = {0};
        
        sockfd = socket(AF_INET,SOCK_DGRAM,0);
        if (sockfd < 0) {
                perror("socket error!\n");
                exit(-1);
        }
        
        memset(&server,0,sizeof(struct sockaddr_in));
        server.sin_family = AF_INET;
        server.sin_addr.s_addr = htonl(INADDR_ANY);
        server.sin_port = htons(7777);
        
        if (bind(sockfd,(struct sockaddr *)&server,sizeof(server)) < 0) {
                perror("bind error!\n");
                exit(-1);
        }
        
        for (;;) {
                cli_len = sizeof(struct sockaddr_in);
                n = recvfrom(sockfd,req,20,0,(struct sockaddr *)&client,&cli_len);
                if (n < 0) {
                        perror("recvfrom error!\n");
                        exit(-1);
                }
                printf("hello!\n");
                
                strncpy(reply,"wangzhe",sizeof("wangzhe"));
                if (sendto(sockfd,reply,20,0,(struct sockaddr *)&client,sizeof(client)) != 20) {
                        perror("sendto error!\n");
                        exit(-1);
                }
        }
        return 0;
}

 

udp_client.c

#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <sys/types.h>
#include <string.h>
#include <unistd.h>

int main(void)
{
        int sockfd,n;
        struct sockaddr_in server;
        //char req[20]={0},reply[20]={0};
	char req[20]={0},reply[20]={0};
        
        sockfd = socket(AF_INET,SOCK_DGRAM,0);
        if (sockfd < 0) {
                perror("socket error!\n");
                exit(-1);
        }
        
        memset(&server,0,sizeof(server));
        server.sin_family = AF_INET;
        server.sin_addr.s_addr = inet_addr("192.168.0.18");
        server.sin_port = htons(7777);
        
#if 1
        strncpy(req,"xiyou",sizeof("xiyou"));
        
        //printf("sendto req to server:%s\n",req);
        
        if (sendto(sockfd,req,20,0,(struct sockaddr *)&server,sizeof(server)) != 20) {
                perror("sendto error!\n");
                exit(-1);
        }
#endif        
	while(1)
	{
        if ((n = recvfrom(sockfd,reply,20,0,(struct sockaddr *)NULL,(int *)NULL)) < 0) {
                perror("recvfrom error!\n");
                exit(-1);
        }
	//printf("recv reply from server :%s\n",reply);
        
        printf("n = %d\n", n);
	sleep(1);
	}
        //printf("recv reply from server :%s\n",reply);
        
	exit(0);
}    

虚拟机里运行client,pc段运行网络调试助手

发现client必须要发送,不然就接受不到数据

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值