Pergunta

Conforme título - alguém pode me ajudar?

Foi útil?

Solução

Obtenha a conversão Jedi da biblioteca ajudante IP da Microsoft a partir do Biblioteca de cabeçalho da API Jedi Jedi - O arquivo é iphlpapi.zip. Desembale os arquivos, você precisa de iptypes.pas e iphlpapi.pas. Então você pode usar algo assim:

procedure TForm1.Button1Click(Sender: TObject);
var
  NumInterfaces: Cardinal;
  AdapterInfo: array of TIpAdapterInfo;
  OutBufLen: ULONG;
  i: integer;
begin
  GetNumberOfInterfaces(NumInterfaces);
  SetLength(AdapterInfo, NumInterfaces);
  OutBufLen := NumInterfaces * SizeOf(TIpAdapterInfo);
  GetAdaptersInfo(@AdapterInfo[0], OutBufLen);

  Memo1.Lines.Clear;
  for i := 0 to NumInterfaces - 1 do begin
    Memo1.Lines.Add(Format('%.2x:%.2x:%.2x:%.2x:%.2x:%.2x',
      [AdapterInfo[i].Address[0], AdapterInfo[i].Address[1],
       AdapterInfo[i].Address[2], AdapterInfo[i].Address[3],
       AdapterInfo[i].Address[4], AdapterInfo[i].Address[5]]));
  end;
end;

(Todo o tratamento de erros omitido, você deve adicioná -lo, é claro.)

Outras dicas

o Função getAdaptersAddresses é a maneira preferida de obter informações de adaptadores desde 2001 com o Windows XP.

As informações do adaptador são retornadas no IP_ADAPTER_ADDRESSES pelo AdapterAddresses parâmetro.

o GetAdaptersAddresses A função pode recuperar informações para IPv4 e IPv6 endereços.

O método recomendado de chamar o GetAdaptersAddresses A função é pré-alocar um buffer de trabalho de 15kb apontado pelo AdapterAddresses parâmetro. Em computadores típicos, isso reduz drasticamente as chances de que o GetAdaptersAddresses função retorna ERROR_BUFFER_OVERFLOW, o que exigiria a chamada GetAdaptersAddresses função várias vezes.


procedure TForm1.Button1Click(Sender: TObject);
const
  AF_UNSPEC = 0;
  GAA_FLAG_INCLUDE_ALL_INTERFACES = $100;
  WORKING_BUFFER_SIZE = 15000;
  MAX_TRIES = 3;
var
  pAddresses,
  pCurrAddresses: PIpAdapterAddresses;
  dwRetVal,
  outBufLen: Cardinal;
  i: Integer;
  macAddress: string;
begin
  Memo1.Lines.Clear;

  outBufLen := WORKING_BUFFER_SIZE;
  pAddresses := nil;
  i := 0;
  repeat
    if Assigned(pAddresses) then
      FreeMem(pAddresses);

    GetMem(pAddresses, outBufLen);
    if not Assigned(pAddresses) then
      raise Exception.Create('Memory allocation failed for IP_ADAPTER_ADDRESSES struct');

    dwRetVal := GetAdaptersAddresses(AF_UNSPEC, GAA_FLAG_INCLUDE_ALL_INTERFACES, nil, pAddresses, @outBufLen);
    Inc(i);
  until (dwRetVal <> ERROR_BUFFER_OVERFLOW) or (i = MAX_TRIES);

  try
    if NO_ERROR <> dwRetVal then begin
      if ERROR_NO_DATA = dwRetVal then begin
        MessageDlg('No addresses were found for the requested parameters', mtInformation, [mbOK], 0);
        Exit;
      end
      else
        raise Exception.Create(SysErrorMessage(dwRetVal));
    end;

    pCurrAddresses := pAddresses;
    while Assigned(pCurrAddresses) do begin
      if pCurrAddresses^.PhysicalAddressLength > 0 then begin
        Memo1.Lines.Add(pCurrAddresses^.FriendlyName);
        macAddress := '';
        for i := 0 to pCurrAddresses^.PhysicalAddressLength - 1 do begin
          if i > 0 then
            macAddress := macAddress + ':';
          macAddress := macAddress + Format('%.2X', [pCurrAddresses^.PhysicalAddress[i]]);
        end;
        Memo1.Lines.Add(macAddress);
        Memo1.Lines.Add('');
      end;
      pCurrAddresses := pCurrAddresses^.Next;
    end;

  finally
    if Assigned(pAddresses) then
      FreeMem(pAddresses);
  end;
end;

Sem saber quase nada sobre Delphi, que tal funcionar %32 % ipconfig.exe /all e analisar a saída?

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top