Как получить MAC-адрес Вашей машины с помощью программы C?

MPI был разработан с сильной связью, вычисляют кластеры с быстрыми, надежными сетями. Распространение и ØMQ разработаны для больших распределенных систем. При разработке параллельного научного приложения пойдите с MPI, но если Вы разрабатываете персистентную распределенную систему, которая должна быть эластичной к отказам и сетевой нестабильности, использовать одного из других.

MPI имеет очень ограниченные средства для отказоустойчивости; поведение обработки ошибок по умолчанию в большинстве реализаций является сбоем в масштабе всей системы. Кроме того, семантика MPI требуют, чтобы все сообщения, отправленные в конечном счете, были использованы. Это имеет много смысла для моделирований на кластере, но не для распределенного приложения.

65
задан Vadim Kotov 18 June 2018 в 11:42
поделиться

6 ответов

Вам необходимо перебрать все доступные интерфейсы на вашем компьютере и использовать ioctl с флагом SIOCGIFHWADDR , чтобы получить MAC-адрес. MAC-адрес будет получен в виде 6-октетного двоичного массива. Вы также хотите пропустить интерфейс обратной петли.

#include <sys/ioctl.h>
#include <net/if.h> 
#include <unistd.h>
#include <netinet/in.h>
#include <string.h>

int main()
{
    struct ifreq ifr;
    struct ifconf ifc;
    char buf[1024];
    int success = 0;

    int sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_IP);
    if (sock == -1) { /* handle error*/ };

    ifc.ifc_len = sizeof(buf);
    ifc.ifc_buf = buf;
    if (ioctl(sock, SIOCGIFCONF, &ifc) == -1) { /* handle error */ }

    struct ifreq* it = ifc.ifc_req;
    const struct ifreq* const end = it + (ifc.ifc_len / sizeof(struct ifreq));

    for (; it != end; ++it) {
        strcpy(ifr.ifr_name, it->ifr_name);
        if (ioctl(sock, SIOCGIFFLAGS, &ifr) == 0) {
            if (! (ifr.ifr_flags & IFF_LOOPBACK)) { // don't count loopback
                if (ioctl(sock, SIOCGIFHWADDR, &ifr) == 0) {
                    success = 1;
                    break;
                }
            }
        }
        else { /* handle error */ }
    }

    unsigned char mac_address[6];

    if (success) memcpy(mac_address, ifr.ifr_hwaddr.sa_data, 6);
}
54
ответ дан 24 November 2019 в 15:09
поделиться

Намного лучше, чем все это безумие с сокетами или оболочками, просто использовать для этого sysfs:

файл / sys / class / net / eth0 / address содержит ваш Mac адрес в виде простой строки, которую можно прочитать с помощью fopen () / fscanf () / fclose () . Нет ничего проще.

И если вы хотите поддерживать другие сетевые интерфейсы, кроме eth0 (а вы, вероятно, захотите), просто используйте opendir () / readdir () / closedir () на / sys / class / net / .

127
ответ дан 24 November 2019 в 15:09
поделиться
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <linux/if.h>
#include <netdb.h>
#include <stdio.h>
#include <string.h>

int main()
{
  struct ifreq s;
  int fd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP);

  strcpy(s.ifr_name, "eth0");
  if (0 == ioctl(fd, SIOCGIFHWADDR, &s)) {
    int i;
    for (i = 0; i < 6; ++i)
      printf(" %02x", (unsigned char) s.ifr_addr.sa_data[i]);
    puts("\n");
    return 0;
  }
  return 1;
}
19
ответ дан 24 November 2019 в 15:09
поделиться
  1. В Linux используйте службу «Network Manager» поверх DBus.

  2. Существует также программа оболочки good'ol , которую можно вызвать и получить результат (используйте функцию exec в C):

$ / sbin / ifconfig | grep HWaddr

1
ответ дан 24 November 2019 в 15:09
поделиться

Очень переносимый способ - проанализировать вывод этой команды.

ifconfig | awk '$0 ~ /HWaddr/ { print $5 }'

При условии, что ifconfig может быть запущен от имени текущего пользователя (обычно может) и awk установлен (часто так и есть). Это даст вам MAC-адрес машины.

0
ответ дан 24 November 2019 в 15:09
поделиться

Вы хотите взглянуть на страницу руководства getifaddrs (3) . На самой странице руководства есть пример на C, который вы можете использовать. Вы хотите получить адрес типа AF_LINK .

24
ответ дан 24 November 2019 в 15:09
поделиться
Другие вопросы по тегам:

Похожие вопросы: