zoukankan      html  css  js  c++  java
  • 通过IP或socket获取对方的MAC地址

    1。通过已经连接的socket文件获取:

    [cpp] view plaincopy
     
    1. int getpeermac( int sockfd, char *buf )  
    2. {  
    3.     int ret =0;  
    4.     struct arpreq arpreq;  
    5.     struct sockaddr_in dstadd_in;  
    6.     socklen_t  len = sizeof( struct sockaddr_in );  
    7.     memset( &arpreq, 0, sizeof( struct arpreq ));  
    8.     memset( &dstadd_in, 0, sizeof( struct sockaddr_in ));  
    9.     if( getpeername( sockfd, (struct sockaddr*)&dstadd_in, &len ) < 0 )  
    10.         err_err("getpeername()");  
    11.     else  
    12.     {  
    13.         memcpy( &arpreq.arp_pa, &dstadd_in, sizeof( struct sockaddr_in ));  
    14.         strcpy(arpreq.arp_dev, "eth1");  
    15.         arpreq.arp_pa.sa_family = AF_INET;  
    16.         arpreq.arp_ha.sa_family = AF_UNSPEC;  
    17.         if( ioctl( sockfd, SIOCGARP, &arpreq ) < 0 )  
    18.             err_err("ioctl SIOCGARP");  
    19.         else  
    20.         {  
    21.             unsigned char* ptr = (unsigned char *)arpreq.arp_ha.sa_data;  
    22.             ret = sprintf(buf, "%02x%02x%02x%02x%02x%02x", *ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5));  
    23.         }  
    24.     }  
    25.     return ret;  
    26. }   

    2。 通过IP获取:

    [cpp] view plaincopy
     
    1. int getpeermac_by_ip(char *ipaddr, char* buf)  
    2. {  
    3.     int     sockfd;  
    4.     unsigned char *ptr;  
    5.     struct arpreq arpreq;  
    6.     struct sockaddr_in *sin;  
    7.     struct sockaddr_storage ss;  
    8.     char addr[INET_ADDRSTRLEN+1];  
    9.   
    10.     memset(addr, 0, INET_ADDRSTRLEN+1);  
    11.     memset(&ss, 0, sizeof(ss));  
    12.     if (argc != 2) {  
    13.         printf("USAGE arpg  ip_addr/n");  
    14.         return -1;  
    15.     }  
    16.     sockfd = socket(AF_INET, SOCK_DGRAM, 0);  
    17.     if (sockfd == -1) {  
    18.         perror("socket error");  
    19.         return -1;  
    20.     }  
    21.     sin = (struct sockaddr_in *) &ss;  
    22.     sin->sin_family = AF_INET;  
    23.     if (inet_pton(AF_INET, argv[1], &(sin->sin_addr)) <= 0) {  
    24.         perror("inet_pton error");  
    25.         return -1;  
    26.     }  
    27.     sin = (struct sockaddr_in *) &arpreq.arp_pa;  
    28.     memcpy(sin, &ss, sizeof(struct sockaddr_in));  
    29.     strcpy(arpreq.arp_dev, "eth1");  
    30.     arpreq.arp_ha.sa_family = AF_UNSPEC;  
    31.     if (ioctl(sockfd, SIOCGARP, &arpreq) < 0) {  
    32.         perror("ioctl SIOCGARP: ");  
    33.         return -1;  
    34.     }  
    35.     ptr = (unsigned char *)arpreq.arp_ha.sa_data;  
    36.     sprintf(buf,"%x:%x:%x:%x:%x:%x", *ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5));  
    37.     return 0;  
    38. }  
  • 相关阅读:
    js定位光标到输入框指定位置
    JS获取本机时间和实时动态时间代码
    一个小游戏
    select optionschange oeder
    js控制下拉列表框
    glow滤镜的使用
    body.innerHTML
    怎样用C语言编写病毒(三)
    2011东北地区赛G题(二分网络流判可行性)
    Codeforces Round #122 (Div. 1)>TLE代码 跪求(n^2)的最小割顶集算法(StoerWagner)
  • 原文地址:https://www.cnblogs.com/lidabo/p/3803870.html
Copyright © 2011-2022 走看看