版权声明:本文为博主原创文章,未经博主允许不得转载。

  1. /********************************** (C) COPYRIGHT *******************************
  2. * File Name          : netstatus_check.c
  3. * Author             : skdkjzz
  4. * Date               : 2014/08/07
  5. * Description        : 检测本机是否连通外部网络(Joseph_Ping 百度)。
  6. *********************************************************************************/
  7. #include <stdio.h>
  8. #include <string.h>
  9. #include <stdlib.h>
  10. #include <sys/socket.h>
  11. #include <netinet/in.h>
  12. #include <netinet/ip.h>
  13. #include <netinet/ip_icmp.h>
  14. #include <netdb.h>
  15. #include <errno.h>
  16. #include <sys/types.h>
  17. #include <netinet/in.h>
  18. #include <sys/types.h>
  19. #include <string.h>
  20. #include <stdlib.h>
  21. #include <sys/types.h>
  22. #include <sys/ioctl.h>
  23. #include <sys/stat.h>
  24. #include <stdio.h>
  25. #include <string.h>
  26. #include <errno.h>
  27. #include <net/if.h>
  28. #include <sys/utsname.h>
  29. #include <limits.h>
  30. #include <ctype.h>
  31. #include <sys/socket.h>
  32. #include <netinet/in.h>
  33. #include <arpa/inet.h>
  34. #include <linux/sockios.h>
  35. #define PACKET_SIZE     4096
  36. #define ERROR           -1
  37. #define SUCCESS         0
  38. /*效验算法*/
  39. unsigned short Joseph_Cal_Chksum(unsigned short *addr, int len)
  40. {
  41. int nleft=len;
  42. int sum=0;
  43. unsigned short *w=addr;
  44. unsigned short answer=0;
  45. while(nleft > 1)
  46. {
  47. sum += *w++;
  48. nleft -= 2;
  49. }
  50. if( nleft == 1)
  51. {
  52. *(unsigned char *)(&answer) = *(unsigned char *)w;
  53. sum += answer;
  54. }
  55. sum = (sum >> 16) + (sum & 0xffff);
  56. sum += (sum >> 16);
  57. answer = ~sum;
  58. return answer;
  59. }
  60. int Joseph_Ping( char *ips,char *srcip , int timeout)    /* Ping函数 */
  61. {
  62. struct timeval *tval;
  63. int maxfds = 0;
  64. fd_set readfds;
  65. struct sockaddr_in addr;
  66. struct sockaddr_in from;
  67. struct ifreq ifr;
  68. bzero(&addr,sizeof(addr));  /* 设定Ip信息 */
  69. addr.sin_family = AF_INET;
  70. addr.sin_addr.s_addr = inet_addr(ips);
  71. int sockfd;
  72. sockfd = socket(AF_INET, SOCK_RAW, IPPROTO_ICMP);   /* 取得socket */
  73. if (sockfd < 0)
  74. {
  75. printf("ip:%s,socket error\n",ips);
  76. return ERROR;
  77. }
  78. struct timeval timeo;
  79. timeo.tv_sec = timeout / 1000;  /* 设定TimeOut时间  */
  80. timeo.tv_usec = timeout % 1000;
  81. #if 0
  82. /*set src ip*/
  83. bzero(&from,sizeof(from));  /* 设定Ip信息 */
  84. from.sin_family = AF_INET;
  85. from.sin_addr.s_addr = inet_addr(srcip);
  86. if (setsockopt(sockfd, IPPROTO_IP, IP_MULTICAST_IF,(struct sockaddr *)&from, sizeof(from)) == -1)
  87. {
  88. printf("ip:%s,setsockopt error \n",srcip);
  89. return ERROR;
  90. }
  91. bind(sockfd,(struct sockaddr *)&addr, sizeof(addr));
  92. #else
  93. strcpy(ifr.ifr_name, srcip);
  94. if (setsockopt(sockfd, SOL_SOCKET, SO_BINDTODEVICE, &ifr, sizeof(ifr)) == -1)
  95. {
  96. printf("can't bind to interface %s\n",ifr.ifr_name);
  97. }
  98. #endif
  99. printf("%s %d\n",__FUNCTION__,__LINE__);
  100. if (setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, &timeo, sizeof(timeo)) == -1)
  101. {
  102. printf("ip:%s,setsockopt error\n",ips);
  103. return ERROR;
  104. }
  105. else
  106. {
  107. printf("ip:%s,setsockopt ok \n",ips);
  108. }
  109. char sendpacket[PACKET_SIZE];
  110. char recvpacket[PACKET_SIZE];
  111. memset(sendpacket, 0, sizeof(sendpacket));   /* 设定Ping包 */
  112. pid_t pid;
  113. pid=getpid();   /* 取得PID,作为Ping的Sequence ID */
  114. struct ip *iph;
  115. struct icmp *icmp;
  116. icmp=(struct icmp*)sendpacket;
  117. icmp->icmp_type=ICMP_ECHO;   /* 回显请求 */
  118. icmp->icmp_code=0;
  119. icmp->icmp_cksum=0;
  120. icmp->icmp_seq=0;
  121. icmp->icmp_id=pid;
  122. tval= (struct timeval *)icmp->icmp_data;
  123. gettimeofday(tval,NULL);
  124. icmp->icmp_cksum=Joseph_Cal_Chksum((unsigned short *)icmp,sizeof(struct icmp));  /* 校验 */
  125. int n;  /* 发包  */
  126. n = sendto(sockfd, (char *)&sendpacket, sizeof(struct icmp), 0, (struct sockaddr *)&addr, sizeof(addr));
  127. if (n < 1)
  128. {
  129. printf("ip:%s,sendto error\n",ips);
  130. return ERROR;
  131. }
  132. while(1)      /* 接受 由于可能接受到其他Ping的应答消息,所以这里要用循环 */
  133. {
  134. FD_ZERO(&readfds);    /* 设定TimeOut时间,这次才是真正起作用的  */
  135. FD_SET(sockfd, &readfds);
  136. maxfds = sockfd + 1;
  137. n = select(maxfds, &readfds, NULL, NULL, &timeo);
  138. if (n <= 0)
  139. {
  140. printf("ip:%s,Time out error\n",ips);
  141. close(sockfd);
  142. return ERROR;
  143. }
  144. memset(recvpacket, 0, sizeof(recvpacket));
  145. int fromlen = sizeof(from);      /* 接受    */
  146. n = recvfrom(sockfd, recvpacket, sizeof(recvpacket), 0, (struct sockaddr *)&from, (socklen_t *)&fromlen);
  147. if (n < 1) {
  148. return ERROR;
  149. }
  150. char *from_ip = (char *)inet_ntoa(from.sin_addr);
  151. if (strcmp(from_ip,ips) != 0)    /* 判断是否是自己Ping的回复 */
  152. {
  153. printf("Now Pingip:%s Fromip:%s\n Now Pingip is not same to Fromip,so Joseph_Ping wrong!\n",ips,from_ip);
  154. return ERROR;
  155. }
  156. iph = (struct ip *)recvpacket;
  157. icmp=(struct icmp *)(recvpacket + (iph->ip_hl<<2));
  158. if (icmp->icmp_type == ICMP_ECHOREPLY && icmp->icmp_id == pid)   /* 判断Ping回复包的状态 ICMP_ECHOREPLY回显应答 */
  159. {
  160. return SUCCESS;
  161. }   /* 正常退出循环 */
  162. else
  163. continue;    /* 否则继续等  */
  164. }
  165. return 0;
  166. }
  167. int main(int argc ,char *argv[])
  168. {
  169. int Qy_Ret = 0;
  170. struct hostent *h=NULL;
  171. char hostname[16]="www.baidu.com";
  172. char aPing[16]="202.108.22.5";  /* Joseph_Ping form ip  */
  173. Qy_Ret = Joseph_Ping(aPing,argv[1],3000);
  174. printf("Qy_Ret is %d\n",Qy_Ret);
  175. if(Qy_Ret == 0)
  176. {
  177. printf("Network is Ok!\n");
  178. return 0;
  179. }
  180. else
  181. {
  182. printf("Network is Bad!\n");
  183. return -1;
  184. }
  185. sprintf(hostname,"%s",(char *)inet_ntoa(*((struct in_addr *)h->h_addr))); /* Joseph_Ping form hostname */
  186. if(Joseph_Ping(hostname,argv[1],3000))
  187. {
  188. printf("Network is Ok!\n");
  189. return 0;
  190. }
  191. else
  192. {
  193. printf("Network is Bad!\n");
  194. return -1;
  195. }
  196. }
  197. </span>

嵌入式 hi3518平台指定网卡测试是否通外网的更多相关文章

  1. [OpenStack] [Liberty] Neutron单网卡桥接模式访问外网

    环境配置: * Exsi一台 * Exsi创建的单网卡虚拟机一台 * Ubuntu 14LTS 64位操作系统 * OpenStack Liberty版本 * 使用Neutron网络而非Nova网络 ...

  2. OpenStack Neutron单网卡桥接模式访问外网

    环境配置: * Exsi一台 * Exsi创建的单网卡虚拟机一台 * Ubuntu 14LTS 64位操作系统 * OpenStack Liberty版本 * 使用Neutron网络而非Nova网络 ...

  3. [原]openstack-kilo--issue(七):虚拟机怎么通外网,外网怎么ping通虚拟机

    =====问题======= 虚拟机可以ping通外网,外网能ping通虚拟机但是收不到reply 这个问题本人遇到有两种情况: 1.安装完整openstack-kilo后,在route中和虚拟机中抓 ...

  4. 关于docker中容器可以Ping通外网,真机无法Ping通容器的问题

    首先我们要知道整体的框架结构,docker是我们安装在centos7上的,而centos7是安装在vmware上.其中docker中还有若干容器运行. 整体框架图如下: 我们将它分为两部分,一部分是d ...

  5. 集群搭建:主机宽带拨号上网,虚拟机使用桥接模式,该如何ping通外网

    首先介绍一下看这篇文章需要的基础.需要了解虚拟机的 虚拟机的三种网络模式,有Linux基础知识,这些都是前提.首先介绍一下我的环境:主机:win7虚拟机:VMware Workstation 10虚拟 ...

  6. 关于开发板不能ping通外网IP

    最近在做远程监控的项目,打算用开发板给一个网站发送数据包.不过发现开发板只能ping通同一局域网内的ip,外网的ip不能ping通.纠结了半天发现是网关没有设置的原因.下面来说说如何解决这个问题. 首 ...

  7. 为虚机Linux系统设置静态IP,ping通外网并解决相关问题

    在虚机中安装完Linux系统后,虚机是ping不通外网的,而默认的动态IP会为之后的Hadoop应用造成不少麻烦,为了减少这些不必要的麻烦,我们把系统的IP设置为静态. 步骤: 修改系统配置文件 命令 ...

  8. 能ping通外网dns但不能上网一例

    一个win7本本仅通过一个无线路由一个人上网,突然一天不能上网了,甚是奇怪,一看本地连接均是正常的.而且能ping通外网的dns,但无论如何就是打不开网页,表现为输入任何网址很迅速的显示该页无法显示, ...

  9. 关于Linux 虚拟机如何才能ping 通外网

    需要虚拟机能够联网.以前都是用桥接模式让虚拟机跟主机通信,这几天查了好多资料,都没有写得很详细,自己捣鼓了很久,把步骤写下来吧. 虚拟机操作步骤: 点击虚拟机的“菜单栏”上的“编辑”,再点击“虚拟网络 ...

随机推荐

  1. TCP三次握手和四次挥手协议

    相对于SOCKET开发者,TCP创建过程和链接折除过程是由TCP/IP协议栈自动创建的.因此开发者并不需要控制这个过程.但是对于理解TCP底层运作机制,相当有帮助. TCP三次握手   所谓三次握手( ...

  2. 超级内存NVDIMM

    1.序言 基于非易失性内存(NVDIMM)的新一代内存条规格已经研制成功,其中集成了DRAM和非易失性存储芯片,能够在完全断电的时候完整保存内存数据,并支持主内存在持久高速高性能计算上的应用.区别于普 ...

  3. QT程序探测所需DLL,静态连接和打包

    1. 如果没有使用静态编译的QT库的话,那么无论VS还是MinGW编译出来的exe程序都要带上一堆DLL,而且必须是准确版本的DLL,对于VS好像还有一个Microsoft.VC90.CRT.mani ...

  4. JavaScript获取DOM元素位置和尺寸大小

      在一些复杂的页面中经常会用JavaScript处理一些DOM元素的动态效果,这种时候我们经常会用到一些元素位置和尺寸的计算,浏览器兼容性问题也是不可忽略的一部分,要想写出预想效果的JavaScri ...

  5. 转:C# 通过委托更新UI(异步加载)

    来自:http://blog.csdn.net/gongzhe2011/article/details/27351853 using System.Windows.Forms; using Syste ...

  6. Docker基础技术:Linux CGroup

    前面,我们介绍了Linux Namespace,但是Namespace解决的问题主要是环境隔离的问题,这只是虚拟化中最最基础的一步,我们还需要解决对计算机资源使用上的隔离.也就是说,虽然你通过Name ...

  7. github简单使用教程(转)

    github是一个基于git的代码托管平台,付费用户可以建私人仓库,我们一般的免费用户只能使用公共仓库,也就是代码要公开.对于一般人来说公共仓库就已经足够了,而且我们也没多少代码来管理,O(∩_∩)O ...

  8. 【转】HashMap的工作原理

    很好的文章,推荐Java的一个好网站:ImportNew HashMap的工作原理是近年来常见的Java面试题.几乎每个Java程序员都知道HashMap,都知道哪里要用HashMap,知道Hasht ...

  9. ACdream 1726 A Math game (dfs+二分)

    http://acdream.info/problem?pid=1726 官方题解:http://acdream.info/topic?tid=4246 求n个数里面能不能选一些数出来让它们的和等于k ...

  10. MyEclipse 10离线安装PyDev插件

    PyDev for Eclipse, 经过测试,一般在线安装会失败(不能访问某些网站所致) 以下为离线安装步骤 1 下载 PyDev 2.8.2,  链接:http://sourceforge.net ...