vc++获取网卡mac、硬盘序列号、cpu+id、bios编号

上传人:第*** 文档编号:30560784 上传时间:2018-01-30 格式:DOC 页数:14 大小:94KB
返回 下载 相关 举报
vc++获取网卡mac、硬盘序列号、cpu+id、bios编号_第1页
第1页 / 共14页
vc++获取网卡mac、硬盘序列号、cpu+id、bios编号_第2页
第2页 / 共14页
vc++获取网卡mac、硬盘序列号、cpu+id、bios编号_第3页
第3页 / 共14页
vc++获取网卡mac、硬盘序列号、cpu+id、bios编号_第4页
第4页 / 共14页
vc++获取网卡mac、硬盘序列号、cpu+id、bios编号_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《vc++获取网卡mac、硬盘序列号、cpu+id、bios编号》由会员分享,可在线阅读,更多相关《vc++获取网卡mac、硬盘序列号、cpu+id、bios编号(14页珍藏版)》请在金锄头文库上搜索。

1、1VC+获取网卡 MAC、硬盘序列号、CPU ID、BIOS 编号以下代码可以取得系统特征码(网卡 MAC、硬盘序列号、CPU ID、BIOS 编号) BYTE szSystemInfo4096; / 在程序执行完毕后,此处存储取得的系统特征码UINT uSystemInfoLen = 0; / 在程序执行完毕后,此处存储取得的系统特征码的长度 / 网卡 MAC 地址,注意: MAC 地址是可以在注册表中修改的UINT uErrorCode=0;IP_ADAPTER_INFO iai;ULONG uSize = 0;DWORD dwResult = GetAdaptersInfo( if( d

2、wResult = ERROR_BUFFER_OVERFLOW )IP_ADAPTER_INFO* piai=( IP_ADAPTER_INFO* )HeapAlloc( GetProcessHeap( ), 0, uSize );if( piai != NULL )dwResult = GetAdaptersInfo( piai, if( ERROR_SUCCESS = dwResult ) IP_ADAPTER_INFO* piai2 = piai;while(piai2!=NULL &(uSystemInfoLen+piai2-AddressLength )Address, piai2-

3、AddressLength );uSystemInfoLen += piai2-AddressLength;piai2 = piai2-Next; elseuErrorCode = 0xF0000000U + dwResult;VERIFY( HeapFree( GetProcessHeap( ), 0, piai ) );elsereturn FALSE;elseuErrorCode = 0xE0000000U + dwResult;if( uErrorCode != 0U )return FALSE; 2/ 硬盘序列号,注意:有的硬盘没有序列号OSVERSIONINFO ovi = 0 ;

4、ovi.dwOSVersionInfoSize = sizeof( OSVERSIONINFO );GetVersionEx( if( ovi.dwPlatformId != VER_PLATFORM_WIN32_NT )/ Only Windows 2000, Windows XP, Windows Server 2003.return FALSE;elseif( !WinNTHDSerialNumAsPhysicalRead( szSystemInfo, &uSystemInfoLen, 1024 ) )WinNTHDSerialNumAsScsiRead( szSystemInfo, /

5、 CPU IDBOOL bException = FALSE;BYTE szCpu16 = 0 ;UINT uCpuID = 0U; _try _asm mov eax, 0cpuidmov dword ptr szCpu0, ebxmov dword ptr szCpu4, edxmov dword ptr szCpu8, ecxmov eax, 1cpuid mov uCpuID, edx_except( EXCEPTION_EXECUTE_HANDLER )bException = TRUE;3if( !bException )CopyMemory( szSystemInfo + uSy

6、stemInfoLen, uSystemInfoLen += sizeof( UINT ); uCpuID = strlen( ( char* )szCpu );CopyMemory( szSystemInfo + uSystemInfoLen, szCpu, uCpuID );uSystemInfoLen += uCpuID;/ BIOS 编号,支持 AMI, AWARD, PHOENIXSIZE_T ssize; LARGE_INTEGER so; so.LowPart=0x000f0000;so.HighPart=0x00000000; ssize=0xffff; wchar_t str

7、PH30=Ldevicephysicalmemory; DWORD ba=0; UNICODE_STRING struniph; struniph.Buffer=strPH; struniph.Length=0x2c; struniph.MaximumLength =0x2e; OBJECT_ATTRIBUTES obj_ar; obj_ar.Attributes =64;obj_ar.Length =24;obj_ar.ObjectName=obj_ar.RootDirectory=0; obj_ar.SecurityDescriptor=0; obj_ar.SecurityQualityO

8、fService =0; HMODULE hinstLib = LoadLibrary(ntdll.dll); ZWOS ZWopenS=(ZWOS)GetProcAddress(hinstLib,ZwOpenSection);ZWMV ZWmapV=(ZWMV)GetProcAddress(hinstLib,ZwMapViewOfSection); ZWUMV ZWunmapV=(ZWUMV)GetProcAddress(hinstLib,ZwUnmapViewOfSection); /调用函数,对物理内存进行映射 HANDLE hSection; if( 0 = ZWopenS(&hSec

9、tion,4,&obj_ar) & 40 = ZWmapV( ( HANDLE )hSection, /打开 Section 时得到的句柄 ( HANDLE )0xFFFFFFFF, /将要映射进程的句柄, &ba, /映射的基址0,0xFFFF, /分配的大小 &so, /物理内存的地址 &ssize, /指向读取内存块大小的指针 1, /子进程的可继承性设定 0, /分配类型 2 /保护类型 ) )/执行后会在当前进程的空间开辟一段 64k 的空间,并把 f000:0000 到 f000:ffff 处的内容映射到这里 /映射的基址由 ba 返回,如果映射不再有用,应该用 ZwUnmapVi

10、ewOfSection 断开映射 BYTE* pBiosSerial = ( BYTE* )ba;UINT uBiosSerialLen = FindAwardBios( if( uBiosSerialLen = 0U )uBiosSerialLen = FindAmiBios( if( uBiosSerialLen = 0U )uBiosSerialLen = FindPhoenixBios( if( uBiosSerialLen != 0U )CopyMemory( szSystemInfo + uSystemInfoLen, pBiosSerial, uBiosSerialLen );u

11、SystemInfoLen += uBiosSerialLen; ZWunmapV( ( HANDLE )0xFFFFFFFF, ( void* )ba );/ 完毕, 系统特征码已取得。 以下是其中用到的某些结构及函数的定义: #define FILE_DEVICE_SCSI 0x0000001b#define IOCTL_SCSI_MINIPORT_IDENTIFY ( ( FILE_DEVICE_SCSI HeaderLength = sizeof( SRB_IO_CONTROL );p-Timeout = 10000;p-Length = SENDIDLENGTH;p-ControlC

12、ode = IOCTL_SCSI_MINIPORT_IDENTIFY;strncpy( ( char* )p-Signature, SCSIDISK, 8 ); pin-irDriveRegs.bCommandReg = IDE_ATA_IDENTIFY;pin-bDriveNumber = iDrive;if( DeviceIoControl( hScsiDriveIOCTL, IOCTL_SCSI_MINIPORT, szBuffer,sizeof( SRB_IO_CONTROL ) + sizeof( SENDCMDINPARAMS ) - 1,szBuffer,sizeof( SRB_

13、IO_CONTROL ) + SENDIDLENGTH, IT 资讯之家 http:/ &dwResult, NULL ) )SENDCMDOUTPARAMS* pOut = ( SENDCMDOUTPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );IDSECTOR* pId = ( IDSECTOR* )( pOut-bBuffer );if( pId-sModelNumber0 )if( * puSerialLen + 20U cBufferSize = IDENTIFY_BUFFER_SIZE;pSCIP-irDriveRegs.bFeat

14、uresReg = 0;pSCIP-irDriveRegs.bSectorCountReg = 1;pSCIP-irDriveRegs.bSectorNumberReg = 1;pSCIP-irDriveRegs.bCylLowReg = 0;pSCIP-irDriveRegs.bCylHighReg = 0; / calc the drive number.pSCIP-irDriveRegs.bDriveHeadReg = 0xA0 | ( ( bDriveNum 10/ The command can either be IDE identify or ATAPI identify.pSC

15、IP-irDriveRegs.bCommandReg = bIDCmd;pSCIP-bDriveNumber = bDriveNum;pSCIP-cBufferSize = IDENTIFY_BUFFER_SIZE;return DeviceIoControl( hPhysicalDriveIOCTL, DFP_RECEIVE_DRIVE_DATA,( LPVOID ) pSCIP,sizeof( SENDCMDINPARAMS ) - 1,( LPVOID ) pSCOP,sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE - 1,lpcbBytesReturned, NULL ); BOOL WinNTHDSerialNumAsPhysicalRead( BYTE* dwSerial, UINT* puSerialLen, UINT uMaxSerialLen )#define DFP

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号