1,我自己写了一个UDP 的小程序,有一个UDP 的server,而且有UDP的client。
然后执行server和client,然后用tcpdump将该端口的UDP数据报文抓取出来。
执行的过程是这样的。
client向server发送"xiyou"
server向client应答"wangzhe"
client程序在主机example上运行(192.168.1.144)
server程序在主机linux上运行(192.168.1.101)
------------------------------------------------------------------------------------------------------------
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>
- int main(void)
- {
- int sockfd,n;
- struct sockaddr_in server;
- 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.1.101");
- server.sin_port = htons(7777);
-
- 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);
- }
-
- 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);
-
- exit(0);
- }
--------------------------------------------------------------------------------------------------------
阅读(11461) | 评论(0) | 转发(1) |