• getmask


    #include "stdio.h"
    #include "stdlib.h"
    #include "string.h"
    
    #include "net/if.h"
    #include "arpa/inet.h"
    #include "linux/sockios.h"
    
    int main(int argc,char *argv[])
    {
        struct sockaddr_in *addr;
        struct ifreq ifr;
        char*address;
        int sockfd;
    
        char *name = "eth0";
        if( strlen(name) >= IFNAMSIZ)
            printf("device name is error.
    "), exit(0);
            
        strcpy( ifr.ifr_name, name);
            
        sockfd = socket(AF_INET,SOCK_DGRAM,0);
    
        //get inet addr
        if( ioctl( sockfd, SIOCGIFADDR, &ifr) == -1)
            printf("ioctl error.
    "), exit(0);
    
        addr = (struct sockaddr_in *)&(ifr.ifr_addr);
        address = inet_ntoa(addr->sin_addr);
    
        printf("inet addr: %s
    ",address);
    
        //get Mask
        if( ioctl( sockfd, SIOCGIFNETMASK, &ifr) == -1)
            printf("ioctl error.
    "), exit(0);
    
        addr = (struct sockaddr_in *)&ifr.ifr_addr;
        address = inet_ntoa(addr->sin_addr);
    
        printf("Mask: %s
    ",address);
    
        //get HWaddr 
        u_int8_t hd[6];
        if(ioctl(sockfd, SIOCGIFHWADDR, &ifr) == -1)
            printf("hwaddr error.
    "), exit(0);
    
        memcpy( hd, ifr.ifr_hwaddr.sa_data, sizeof(hd));
        printf("HWaddr: %02X:%02X:%02X:%02X:%02X:%02X
    ", hd[0], hd[1], hd[2], hd[3], hd[4], hd[5]);
        
        exit(0);
    }
  • 相关阅读:
    JSONObject登录接口
    HttpClient跨域请求post
    线段树个人理解及模板
    Python基本语法(一)
    Boyer-Moore算法
    Sunday算法浅谈
    Kmp算法浅谈
    bm坏字符 , Horspool算法 以及Sunday算法的不同
    字典树的建立和基本查找
    CF Round551 Div2 题解
  • 原文地址:https://www.cnblogs.com/timssd/p/4091033.html
Copyright © 2020-2023  润新知