资源简介
ICMP[version 4]的echo报文运用,模拟ping命令实现pingy命令
代码片段和文件信息
#include
#include
#include
#include
#include “ping.h“
#define ICMP_ECHOREPLY 0
#define ICMP_ECHOREQ 8
// statistics
int nsend = 0 nrecv = 0;
int rrt[10];
int packsize;
void get_data(int rrt[] int size int *min int *max int *avg);
void tv_sub(struct timeval *outstruct timeval *in);
// calculate checksum of icmp header
uint16_t cal_cksum(uint16_t *addr int len)
{
int nleft = len;
uint32_t sum = 0;
uint16_t *w = addr;
uint16_t answer = 0;
while (nleft > 1) {
sum += *w++;
nleft -= 2;
}
if (nleft == 1) {
*(unsigned char *)(&answer) = *(unsigned char *)w ;
sum += answer;
}
sum = (sum >> 16) + (sum & 0xffff);
sum += (sum >> 16);
answer = ~sum;
return(answer);
}
void print_head(char *ip)
{
packsize = sizeof(struct icmp) + sizeof(struct timeval);
printf(“Ping %s with %d bytes of data:\n“ ip packsize);
}
void print_stat(char *ip)
{
int min_rrt max_rrt avg_rrt;
int lost;
if(nsend < 1)
return;
get_data(rrt nsend &min_rrt &max_rrt &avg_rrt);
lost = nsend - nrecv;
printf(“========================================================================\n“);
printf(“Ping Statistics for %s:\n“ ip);
printf(“\tPackets: Send = %d Received = %d Lost = %d(%.1f%% lost)\n“ nsend nrecv lost (lost / (nsend * 1.0) * 100.0));
printf(“Approximate round trip times in milli-seconds:\n“);
printf(“\tMinimum = %dms Maximum = %dms Average = %dms\n“ min_rrt max_rrt avg_rrt);
}
void send_ping(int sockfd struct sockaddr_in *dstaddr)
{
char buf[100];
size_t len = sizeof(struct icmp);
socklen_t dstlen = sizeof(struct sockaddr_in);
struct icmp *echo;
memset(buf 0 sizeof(buf));
echo = (struct icmp*)buf;
echo = (struct icmp *)buf;
echo->icmp_type = ICMP_ECHOREQ;
echo->icmp_code = 0;
echo->icmp_cksum = 0;
echo->icmp_id = getpid();
echo->icmp_seq = nsend;
struct timeval *tval= (struct timeval *)echo->icmp_data;
gettimeofday(tvalNULL);
echo->icmp_cksum = cal_cksum((uint16_t *)echo packsize);
// send ping message
if(sendto(sockfd buf len 0 (struct sockaddr*)dstaddr dstlen) == -1)
printf(“Send Ping Message Error!\n“);
nsend++;
}
void recv_ping(int sockfd struct sockaddr_in *dstaddr)
{
char buf[100];
ssize_t n;
struct ip *ip;
struct icmp *icmp;
socklen_t dstlen = sizeof(struct sockaddr_in);
int ttl;
fd_set rset;
int maxfd = sockfd + 1;
struct timeval timeo *tvsend tvrecv;
unsigned char *p;
unsigned char ipaddr[100];
int time;
memset(buf 0 sizeof(buf));
timeo.tv_sec = 3;
timeo.tv_usec = 0;
FD_ZERO(&rset);
FD_SET(sockfd &rset);
gettimeofday(&tvrecv NULL);
while(1)
{
// set timeout 3s
if((n = select(maxfd &rset NULL NULL &timeo)) == -1)
{
printf(“Select Error!\n“);
exit(1);
}
if(n <= 0)
{
printf(“Request Time Out!\n“);
fflush(stdout);
break;
}
if((n = recvf
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 184 2010-03-10 11:20 PingY\makefile
文件 5182 2010-03-10 11:04 PingY\ping.c
文件 1348 2010-03-09 11:13 PingY\ping.h
文件 2148 2010-03-10 11:21 PingY\PingPro.c
目录 0 2010-03-29 20:34 PingY
----------- --------- ---------- ----- ----
8862 5
相关资源
- linux下802.11协议csma/ca 的C程序实现
- TCP文件传输的设计与实现
- Leach协议仿真的nam动画实现
- VHDL和FPGA实现四位数据比较器
- 基于FPGA实现Modbus通讯协议
- 51单片机实现的RS485通讯程序
- 操作系统-页面置换算法的模拟实现及
- s7-300交通灯控制程序含三种实现方法
- VHDL语言实现简易多功能信号发生器
- ad hoc网络olsr路由在linux下的实现源代
- 数据结构课设散列表的设计与实现
- PPT、Excel实现随机抽题.rar
- arduino new ping
- 模糊神经网络 matlab实现
- 光伏电池最大功率跟踪仿真,能够了
- Echarts实现的地图关联柱状图
- h5 录音功能的综合实现
- h5 录音功能的实现
- 汇编实现一位十进制加减乘除四则运
- 实现网页短信验证登录
- 用51单片机实现计算器功能
- 汇编实现显示键盘的字母的ASCII 和扫
- Verilog HDL实现数码管动态扫描
- 学生信息管理系统的开发与实现
- 一次性口令认证系统SKEY的实现
- 租房系统 使用ssh框架 利用Struts2框架
- 用栈实现汉诺塔问题
- css3实现的15种二级下拉导航加载动画
- 基于单片机的语音控制小车系统设计
- QT实现的模拟win+r窗口
评论
共有 条评论