基本信息
源码名称:C/C++获取设备MAC地址
源码大小:4.33KB
文件格式:.zip
开发语言:C/C++
更新时间:2019-06-25
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
获取设备MAC地址
获取设备MAC地址
MacAddress.cpp
#include <stdio.h> #include <locale.h> #include <tchar.h> #include <windows.h> #include <shlwapi.h> #include <setupapi.h> #pragma comment(lib, "setupapi.lib") #include <devguid.h> #pragma comment(lib, "uuid.lib") #include <ntddndis.h> #include <ndisguid.h> #include <iptypes.h> #include <regstr.h> using DIDD_TYPE_BASE = SP_DEVICE_INTERFACE_DETAIL_DATA; using DIDD_TYPE_CHAR = decltype(*static_cast<DIDD_TYPE_BASE *>(nullptr)->DevicePath); static constexpr SIZE_T DIDD_SIZE_HEAD = offsetof(DIDD_TYPE_BASE, DevicePath); static constexpr SIZE_T DIDD_SIZE_BODY = sizeof(DIDD_TYPE_CHAR) * MAX_PATH; static constexpr SIZE_T DIDD_SIZE_FULL = DIDD_SIZE_HEAD DIDD_SIZE_BODY; using DEVICE_INTERFACE_DETAIL_DATA = union DEVICE_INTERFACE_DETAIL_DATA { inline SP_DEVICE_INTERFACE_DETAIL_DATA *operator->() { return &DetailData; } inline SP_DEVICE_INTERFACE_DETAIL_DATA *operator &() { return &DetailData; } SP_DEVICE_INTERFACE_DETAIL_DATA DetailData; BYTE Buffer[DIDD_SIZE_FULL]; }; static BOOL SetupDiGetDeviceInfoDetail(HDEVINFO hDevInfo, const GUID *pClassGuid, SP_DEVINFO_DATA *pDevInfo, SP_DEVICE_INTERFACE_DETAIL_DATA *pvDetail, DWORD cbDetail, DWORD *pcbRequired) { TCHAR szInstId[256] = { 0 }; DWORD cchInstId = ARRAYSIZE(szInstId); DWORD cchRequired = 0; BOOL bResult = SetupDiGetDeviceInstanceId(hDevInfo, pDevInfo, szInstId, cchInstId, &cchRequired); if (bResult) { hDevInfo = SetupDiGetClassDevs(pClassGuid, szInstId, nullptr, DIGCF_DEVICEINTERFACE); if (hDevInfo != INVALID_HANDLE_VALUE) { SP_DEVICE_INTERFACE_DATA spdid = { 0 }; spdid.cbSize = sizeof(SP_DEVICE_INTERFACE_DATA); __try { bResult = SetupDiEnumDeviceInterfaces(hDevInfo, nullptr, pClassGuid, 0, &spdid); if (!bResult) { __leave; } bResult = SetupDiGetDeviceInterfaceDetail(hDevInfo, &spdid, pvDetail, cbDetail, pcbRequired, nullptr); if (!bResult) { __leave; } } __finally { SetupDiDestroyDeviceInfoList(hDevInfo); } } else { bResult = FALSE; } } return bResult; } static void SetupDiOutputDeviceProperty(HDEVINFO hDevInfo, SP_DEVINFO_DATA *pDevInfo) { struct { PCTSTR pszProp; DWORD dwProp; } PropInfo[] = { { _T("枚举类型"), SPDRP_ENUMERATOR_NAME }, { _T("设备名称"), SPDRP_FRIENDLYNAME }, { _T("设备描述"), SPDRP_DEVICEDESC }, { _T("制 造 商"), SPDRP_MFG }, }; for (auto prop : PropInfo) { DWORD dwType = REG_NONE; TCHAR szInfo[1024] = { 0 }; DWORD cbInfo = sizeof(szInfo); BOOL bResult = SetupDiGetDeviceRegistryProperty(hDevInfo, pDevInfo, prop.dwProp, &dwType, reinterpret_cast<BYTE *>(szInfo), cbInfo, nullptr); if (bResult) { wprintf(L"%s [%s]\n", prop.pszProp, szInfo); } } } static void SetupDiOutputDeviceAddress(LPCTSTR DevicePath) { HANDLE hFile = CreateFile(DevicePath, GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, nullptr, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, nullptr); if (hFile != INVALID_HANDLE_VALUE) { BOOL bResult = FALSE; BYTE bAddress[MAX_ADAPTER_ADDRESS_LENGTH] = { 0 }; DWORD dwCtls[] = { OID_802_3_PERMANENT_ADDRESS, OID_802_3_CURRENT_ADDRESS }; for (DWORD i = 0; i < ARRAYSIZE(dwCtls); i ) { DWORD dwCode = dwCtls[i]; DWORD cbRead = 0; bResult = DeviceIoControl(hFile, IOCTL_NDIS_QUERY_GLOBAL_STATS, &dwCode, sizeof(dwCode), bAddress, sizeof(bAddress), &cbRead, nullptr); if (bResult) { wprintf(L"网卡地址 [%02X-%02X-%02X-%02X-%02X-%02X]\n", bAddress[0], bAddress[1], bAddress[2], bAddress[3], bAddress[4], bAddress[5]); break; } } DWORD dwType = 0; DWORD dwCode = OID_GEN_PHYSICAL_MEDIUM; DWORD cbRead = 0; bResult = DeviceIoControl(hFile, IOCTL_NDIS_QUERY_GLOBAL_STATS, &dwCode, sizeof(dwCode), &dwType, sizeof(dwType), &cbRead, nullptr); CloseHandle(hFile); if (bResult) { BOOL bWireless = FALSE; switch (dwType) { case NdisPhysicalMediumWirelessLan: case NdisPhysicalMediumWirelessWan: case NdisPhysicalMediumNative802_11: case NdisPhysicalMediumBluetooth: case NdisPhysicalMediumWiMax: case NdisPhysicalMediumUWB: bWireless = TRUE; default: wprintf(L"是否无线 [%d]\n", bWireless); break; } } } } /****************************************************************************** *** main ******************************************************************************/ int __cdecl _tmain(int argc, _TCHAR *argv[]) { setlocale(LC_CTYPE, ".ACP"); HDEVINFO hDevInfo = SetupDiGetClassDevs(&GUID_DEVCLASS_NET, REGSTR_KEY_PCIENUM, nullptr, DIGCF_PRESENT); if (hDevInfo != INVALID_HANDLE_VALUE) { BOOL bResult; int nDevice = 0; do { SP_DEVINFO_DATA spdd = { 0 }; spdd.cbSize = sizeof(SP_DEVINFO_DATA); bResult = SetupDiEnumDeviceInfo(hDevInfo, nDevice , &spdd); if (!bResult) { break; } DEVICE_INTERFACE_DETAIL_DATA spdidd = { 0 }; spdidd->cbSize = sizeof(SP_DEVICE_INTERFACE_DETAIL_DATA); bResult = SetupDiGetDeviceInfoDetail(hDevInfo, &GUID_DEVINTERFACE_NET, &spdd, &spdidd, sizeof(spdidd), nullptr); if (!bResult) { break; } wprintf(L"################################################################################\n"); SetupDiOutputDeviceProperty(hDevInfo, &spdd); SetupDiOutputDeviceAddress(spdidd->DevicePath); } while (1); SetupDiDestroyDeviceInfoList(hDevInfo); } return !getchar(); }