挂海论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
 友情提示:文字/图片广告均非网站意见,请担保交易勿直接付款,由此产生的责任自负
玩游戏来117游戏网(H5不下载也能玩手游传奇,吃鸡,竞技都有)天下盾/国内/免实名/免备案CDN无视一切CC/DD攻击 找塔科夫作者TG @wuhao1954 QQ283931494 出租内核驱动读写保护,价格亲民,高品质群:530544047 →入驻S9企业发卡网各种全黑号辅助群:475351077
██【我要租此广告位】██... .
查看: 20633|回复: 25
打印 上一主题 下一主题

获取机器唯一标识【硬盘ID,MAC,处理器ID】

[复制链接]

4万

积分

621

主题

168

听众
已帮网友解决4 个问题
好评
1010
贡献
47462
海币
3755
交易币
2000

最佳新人活跃会员开荒者原创大师推广达人沙发王侦察队队长宣传达人灌水之王突出贡献优秀版主荣誉管理论坛元老在线王源码大师终身成就杰出贡献机器王评分大师回帖大师CM制造者CM杀手艺术大师签到达人土豪知识库

QQ
跳转到指定楼层
楼主
发表于 2014-6-21 14:15:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
提醒:若下载的软件是收费的"请不要付款",可能是骗子,请立即联系本站举报,执意要付款被骗后本站概不负责。(任何交易请走第三方中介,请勿直接付款交易以免被骗!切记).

友情提示:文字/图片广告均非本站意见,请担保交易勿直接付款,由此产生的责任自负!!!↑↑


本文中所有原理及思想均取自网络,有修改。其中获取硬盘序列号、获取CPU编号、获取BIOS编号的原始代码的著作权归各自作者所有。




  以下代码可以取得系统特征码(网卡MAC、硬盘序列号、CPU ID、BIOS编号)


    BYTE szSystemInfo[4096]; // 在程序执行完毕后,此处存储取得的系统特征码
    UINT uSystemInfoLen = 0; // 在程序执行完毕后,此处存储取得的系统特征码的长度

  1. <p> // 网卡 MAC 地址,注意: MAC 地址是可以在注册表中修改的
  2.     {
  3.         UINT uErrorCode = 0;
  4.         IP_ADAPTER_INFO iai;
  5.         ULONG uSize = 0;
  6.         DWORD dwResult = GetAdaptersInfo( &iai, &uSize );
  7.         if( dwResult == ERROR_BUFFER_OVERFLOW )
  8.         {
  9.             IP_ADAPTER_INFO* piai = ( IP_ADAPTER_INFO* )HeapAlloc( GetProcessHeap( ), 0, uSize );
  10.             if( piai != NULL )
  11.             {
  12.                 dwResult = GetAdaptersInfo( piai, &uSize );
  13.                 if( ERROR_SUCCESS == dwResult )
  14.                 {
  15.                     IP_ADAPTER_INFO* piai2 = piai;
  16.                     while( piai2 != NULL && ( uSystemInfoLen + piai2->AddressLength ) < 4096U )
  17.                     {
  18.                         CopyMemory( szSystemInfo + uSystemInfoLen, piai2->Address, piai2->AddressLength );
  19.                         uSystemInfoLen += piai2->AddressLength;
  20.                         piai2 = piai2->Next;                        
  21.                     }
  22.                 }
  23.                 else
  24.                 {
  25.                     uErrorCode = 0xF0000000U + dwResult;
  26.                 }
  27.                 VERIFY( HeapFree( GetProcessHeap( ), 0, piai ) );
  28.             }
  29.             else
  30.             {
  31.                 return FALSE;
  32.             }
  33.         }
  34.         else
  35.         {
  36.             uErrorCode = 0xE0000000U + dwResult;
  37.         }
  38.         if( uErrorCode != 0U )
  39.         {
  40.             return FALSE;
  41.         }
  42.     }

  43.     // 硬盘序列号,注意:有的硬盘没有序列号
  44.     {
  45.         OSVERSIONINFO ovi = { 0 };
  46.         ovi.dwOSVersionInfoSize = sizeof( OSVERSIONINFO );
  47.         GetVersionEx( &ovi );
  48.          
  49.         if( ovi.dwPlatformId != VER_PLATFORM_WIN32_NT )
  50.         {
  51.             // Only Windows 2000, Windows XP, Windows Server 2003...
  52.             return FALSE;
  53.         }
  54.         else
  55.         {
  56.             if( !WinNTHDSerialNumAsPhysicalRead( szSystemInfo, &uSystemInfoLen, 1024 ) )
  57.             {
  58.                 WinNTHDSerialNumAsScsiRead( szSystemInfo, &uSystemInfoLen, 1024 );
  59.             }
  60.         }
  61.     }

  62.     // CPU ID
  63.     {
  64.         BOOL bException = FALSE;
  65.         BYTE szCpu[16]  = { 0 };
  66.         UINT uCpuID     = 0U;

  67.         __try
  68.         {
  69.             _asm
  70.             {
  71.                 mov eax, 0
  72.                 cpuid
  73.                 mov dword ptr szCpu[0], ebx
  74.                 mov dword ptr szCpu[4], edx
  75.                 mov dword ptr szCpu[8], ecx
  76.                 mov eax, 1
  77.                 cpuid
  78.                 mov uCpuID, edx
  79.             }
  80.         }
  81.         __except( EXCEPTION_EXECUTE_HANDLER )
  82.         {
  83.             bException = TRUE;
  84.         }
  85.          
  86.         if( !bException )
  87.         {
  88.             CopyMemory( szSystemInfo + uSystemInfoLen, &uCpuID, sizeof( UINT ) );
  89.             uSystemInfoLen += sizeof( UINT );

  90.             uCpuID = strlen( ( char* )szCpu );
  91.             CopyMemory( szSystemInfo + uSystemInfoLen, szCpu, uCpuID );
  92.             uSystemInfoLen += uCpuID;
  93.         }
  94.     }
  95.      
  96.     // BIOS 编号,支持 AMI, AWARD, PHOENIX
  97.     {
  98.         SIZE_T ssize;

  99.         LARGE_INTEGER so;
  100.         so.LowPart=0x000f0000;
  101.         so.HighPart=0x00000000;
  102.         ssize=0xffff;
  103.         wchar_t strPH[30]=L\\device\\physicalmemory;

  104.         DWORD ba=0;

  105.         UNICODE_STRING struniph;
  106.         struniph.Buffer=strPH;
  107.         struniph.Length=0x2c;
  108.         struniph.MaximumLength =0x2e;

  109.         OBJECT_ATTRIBUTES obj_ar;
  110.         obj_ar.Attributes =64;
  111.         obj_ar.Length =24;
  112.         obj_ar.ObjectName=&struniph;
  113.         obj_ar.RootDirectory=0;
  114.         obj_ar.SecurityDescriptor=0;
  115.         obj_ar.SecurityQualityOfService =0;

  116.         HMODULE hinstLib = LoadLibrary("ntdll.dll");
  117.         ZWOS ZWopenS=(ZWOS)GetProcAddress(hinstLib,"ZwOpenSection");
  118.         ZWMV ZWmapV=(ZWMV)GetProcAddress(hinstLib,"ZwMapViewOfSection");
  119.         ZWUMV ZWunmapV=(ZWUMV)GetProcAddress(hinstLib,"ZwUnmapViewOfSection");
  120.          
  121.         //调用函数,对物理内存进行映射
  122.         HANDLE hSection;
  123.         if( 0 == ZWopenS(&hSection,4,&obj_ar) &&
  124.             0 == ZWmapV(
  125.             ( HANDLE )hSection,   //打开Section时得到的句柄
  126.             ( HANDLE )0xFFFFFFFF, //将要映射进程的句柄,
  127.             &ba,                  //映射的基址
  128.             0,
  129.             0xFFFF,               //分配的大小
  130.             &so,                  //物理内存的地址
  131.             &ssize,               //指向读取内存块大小的指针
  132.             1,                    //子进程的可继承性设定
  133.             0,                    //分配类型
  134.             2                     //保护类型
  135.             ) )
  136.         //执行后会在当前进程的空间开辟一段64k的空间,并把f000:0000到f000:ffff处的内容映射到这里
  137.         //映射的基址由ba返回,如果映射不再有用,应该用ZwUnmapViewOfSection断开映射
  138.         {
  139.             BYTE* pBiosSerial = ( BYTE* )ba;
  140.             UINT uBiosSerialLen = FindAwardBios( &pBiosSerial );
  141.             if( uBiosSerialLen == 0U )
  142.             {
  143.                 uBiosSerialLen = FindAmiBios( &pBiosSerial );
  144.                 if( uBiosSerialLen == 0U )
  145.                 {
  146.                     uBiosSerialLen = FindPhoenixBios( &pBiosSerial );
  147.                 }
  148.             }
  149.             if( uBiosSerialLen != 0U )
  150.             {
  151.                 CopyMemory( szSystemInfo + uSystemInfoLen, pBiosSerial, uBiosSerialLen );
  152.                 uSystemInfoLen += uBiosSerialLen;
  153.             }
  154.             ZWunmapV( ( HANDLE )0xFFFFFFFF, ( void* )ba );
  155.         }
  156.     }
  157.     // 完毕, 系统特征码已取得。

  158.   

  159. 2回顶部
  160.   

  161.   以下是其中用到的某些结构及函数的定义:

  162. #define  FILE_DEVICE_SCSI              0x0000001b
  163. #define  IOCTL_SCSI_MINIPORT_IDENTIFY  ( ( FILE_DEVICE_SCSI << 16 ) + 0x0501 )

  164. #define  IOCTL_SCSI_MINIPORT 0x0004D008  //  see NTDDSCSI.H for definition

  165. #define  IDENTIFY_BUFFER_SIZE  512
  166. #define  SENDIDLENGTH  ( sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE )

  167. #define  IDE_ATAPI_IDENTIFY  0xA1  //  Returns ID sector for ATAPI.
  168. #define  IDE_ATA_IDENTIFY    0xEC  //  Returns ID sector for ATA.
  169. #define  DFP_RECEIVE_DRIVE_DATA   0x0007c088

  170. typedef struct _IDSECTOR
  171. {
  172.     USHORT  wGenConfig;
  173.     USHORT  wNumCyls;
  174.     USHORT  wReserved;
  175.     USHORT  wNumHeads;
  176.     USHORT  wBytesPerTrack;
  177.     USHORT  wBytesPerSector;
  178.     USHORT  wSectorsPerTrack;
  179.     USHORT  wVendorUnique[3];
  180.     CHAR    sSerialNumber[20];
  181.     USHORT  wBufferType;
  182.     USHORT  wBufferSize;
  183.     USHORT  wECCSize;
  184.     CHAR    sFirmwareRev[8];
  185.     CHAR    sModelNumber[40];
  186.     USHORT  wMoreVendorUnique;
  187.     USHORT  wDoubleWordIO;
  188.     USHORT  wCapabilities;
  189.     USHORT  wReserved1;
  190.     USHORT  wPIOTiming;
  191.     USHORT  wDMATiming;
  192.     USHORT  wBS;
  193.     USHORT  wNumCurrentCyls;
  194.     USHORT  wNumCurrentHeads;
  195.     USHORT  wNumCurrentSectorsPerTrack;
  196.     ULONG   ulCurrentSectorCapacity;
  197.     USHORT  wMultSectorStuff;
  198.     ULONG   ulTotalAddressableSectors;
  199.     USHORT  wSingleWordDMA;
  200.     USHORT  wMultiWordDMA;
  201.     BYTE    bReserved[128];
  202. } IDSECTOR, *PIDSECTOR;

  203. typedef struct _DRIVERSTATUS

  204. {
  205.     BYTE  bDriverError;  //  Error code from driver, or 0 if no error.
  206.     BYTE  bIDEStatus;    //  Contents of IDE Error register.
  207.     //  Only valid when bDriverError is SMART_IDE_ERROR.
  208.     BYTE  bReserved[2];  //  Reserved for future expansion.
  209.     DWORD  dwReserved[2];  //  Reserved for future expansion.
  210. } DRIVERSTATUS, *PDRIVERSTATUS, *LPDRIVERSTATUS;

  211. typedef struct _SENDCMDOUTPARAMS
  212. {
  213.     DWORD         cBufferSize;   //  Size of bBuffer in bytes
  214.     DRIVERSTATUS  DriverStatus;  //  Driver status structure.
  215.     BYTE          bBuffer[1];    //  Buffer of arbitrary length in which to store the data read from the                                                       // drive.
  216. } SENDCMDOUTPARAMS, *PSENDCMDOUTPARAMS, *LPSENDCMDOUTPARAMS;

  217. typedef struct _SRB_IO_CONTROL
  218. {
  219.     ULONG HeaderLength;
  220.     UCHAR Signature[8];
  221.     ULONG Timeout;
  222.     ULONG ControlCode;
  223.     ULONG ReturnCode;
  224.     ULONG Length;
  225. } SRB_IO_CONTROL, *PSRB_IO_CONTROL;

  226. typedef struct _IDEREGS
  227. {
  228.     BYTE bFeaturesReg;       // Used for specifying SMART "commands".
  229.     BYTE bSectorCountReg;    // IDE sector count register
  230.     BYTE bSectorNumberReg;   // IDE sector number register
  231.     BYTE bCylLowReg;         // IDE low order cylinder value
  232.     BYTE bCylHighReg;        // IDE high order cylinder value
  233.     BYTE bDriveHeadReg;      // IDE drive/head register
  234.     BYTE bCommandReg;        // Actual IDE command.
  235.     BYTE bReserved;          // reserved for future use.  Must be zero.
  236. } IDEREGS, *PIDEREGS, *LPIDEREGS;

  237. typedef struct _SENDCMDINPARAMS
  238. {
  239.     DWORD     cBufferSize;   //  Buffer size in bytes
  240.     IDEREGS   irDriveRegs;   //  Structure with drive register values.
  241.     BYTE bDriveNumber;       //  Physical drive number to send
  242.     //  command to (0,1,2,3).
  243.     BYTE bReserved[3];       //  Reserved for future expansion.
  244.     DWORD     dwReserved[4]; //  For future use.
  245.     BYTE      bBuffer[1];    //  Input buffer.
  246. } SENDCMDINPARAMS, *PSENDCMDINPARAMS, *LPSENDCMDINPARAMS;

  247. typedef struct _GETVERSIONOUTPARAMS
  248. {
  249.     BYTE bVersion;      // Binary driver version.
  250.     BYTE bRevision;     // Binary driver revision.
  251.     BYTE bReserved;     // Not used.
  252.     BYTE bIDEDeviceMap; // Bit map of IDE devices.
  253.     DWORD fCapabilities; // Bit mask of driver capabilities.
  254.     DWORD dwReserved[4]; // For future use.
  255. } GETVERSIONOUTPARAMS, *PGETVERSIONOUTPARAMS, *LPGETVERSIONOUTPARAMS;

  256. //////////////////////////////////////////////////////////////////////

  257. //结构定义
  258. typedef struct _UNICODE_STRING
  259. {
  260.     USHORT  Length;//长度
  261.     USHORT  MaximumLength;//最大长度
  262.     PWSTR  Buffer;//缓存指针
  263. } UNICODE_STRING,*PUNICODE_STRING;

  264. typedef struct _OBJECT_ATTRIBUTES
  265. {
  266.     ULONG Length;//长度 18h
  267.     HANDLE RootDirectory;//  00000000
  268.     PUNICODE_STRING ObjectName;//指向对象名的指针
  269.     ULONG Attributes;//对象属性00000040h
  270.     PVOID SecurityDescriptor;        // Points to type SECURITY_DESCRIPTOR,0
  271.     PVOID SecurityQualityOfService;  // Points to type SECURITY_QUALITY_OF_SERVICE,0
  272. } OBJECT_ATTRIBUTES;
  273. typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;

  274. //函数指针变量类型
  275. typedef DWORD  (__stdcall *ZWOS )( PHANDLE,ACCESS_MASK,POBJECT_ATTRIBUTES);
  276. typedef DWORD  (__stdcall *ZWMV )( HANDLE,HANDLE,PVOID,ULONG,ULONG,PLARGE_INTEGER,PSIZE_T,DWORD,ULONG,ULONG);
  277. typedef DWORD  (__stdcall *ZWUMV )( HANDLE,PVOID);

  278. BOOL WinNTHDSerialNumAsScsiRead( BYTE* dwSerial, UINT* puSerialLen, UINT uMaxSerialLen )
  279. {
  280.     BOOL bInfoLoaded = FALSE;
  281.      
  282.     for( int iController = 0; iController < 2; ++ iController )
  283.     {
  284.         HANDLE hScsiDriveIOCTL = 0;
  285.         char   szDriveName[256];
  286.          
  287.         //  Try to get a handle to PhysicalDrive IOCTL, report failure
  288.         //  and exit if can't.
  289.         sprintf( szDriveName, "<a>\\\\.\\Scsi%d</a>:", iController );

  290.         //  Windows NT, Windows 2000, any rights should do
  291.         hScsiDriveIOCTL = CreateFile( szDriveName,
  292.             GENERIC_READ | GENERIC_WRITE,
  293.             FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,
  294.             OPEN_EXISTING, 0, NULL);

  295.         // if (hScsiDriveIOCTL == INVALID_HANDLE_VALUE)
  296.         //    printf ("Unable to open SCSI controller %d, error code: 0x%lX\n",
  297.         //            controller, GetLastError ());
  298.          
  299.         if( hScsiDriveIOCTL != INVALID_HANDLE_VALUE )
  300.         {
  301.             int iDrive = 0;
  302.             for( iDrive = 0; iDrive < 2; ++ iDrive )
  303.             {
  304.                 char szBuffer[sizeof( SRB_IO_CONTROL ) + SENDIDLENGTH] = { 0 };

  305.                 SRB_IO_CONTROL* p = ( SRB_IO_CONTROL* )szBuffer;
  306.                 SENDCMDINPARAMS* pin = ( SENDCMDINPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );
  307.                 DWORD dwResult;

  308.                 p->HeaderLength = sizeof( SRB_IO_CONTROL );
  309.                 p->Timeout = 10000;
  310.                 p->Length = SENDIDLENGTH;
  311.                 p->ControlCode = IOCTL_SCSI_MINIPORT_IDENTIFY;
  312.                 strncpy( ( char* )p->Signature, "SCSIDISK", 8 );

  313.                 pin->irDriveRegs.bCommandReg = IDE_ATA_IDENTIFY;
  314.                 pin->bDriveNumber = iDrive;
  315.                  
  316.                 if( DeviceIoControl( hScsiDriveIOCTL, IOCTL_SCSI_MINIPORT,
  317.                     szBuffer,
  318.                     sizeof( SRB_IO_CONTROL ) + sizeof( SENDCMDINPARAMS ) - 1,
  319.                     szBuffer,
  320.                     sizeof( SRB_IO_CONTROL ) + SENDIDLENGTH,
  321.                     &dwResult, NULL ) )
  322.                 {
  323.                     SENDCMDOUTPARAMS* pOut = ( SENDCMDOUTPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );
  324.                     IDSECTOR* pId = ( IDSECTOR* )( pOut->bBuffer );
  325.                     if( pId->sModelNumber[0] )
  326.                     {
  327.                         if( * puSerialLen + 20U <= uMaxSerialLen )
  328.                         {
  329.                             // 序列号
  330.                             CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )pId ) + 10, 20 );

  331.                             // Cut off the trailing blanks
  332.                             for( UINT i = 20; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )
  333.                             {}
  334.                             * puSerialLen += i;

  335.                             // 型号
  336.                             CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )pId ) + 27, 40 );
  337.                             // Cut off the trailing blanks
  338.                             for( i = 40; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )
  339.                             {}
  340.                             * puSerialLen += i;

  341.                             bInfoLoaded = TRUE;
  342.                         }
  343.                         else
  344.                         {
  345.                             ::CloseHandle( hScsiDriveIOCTL );
  346.                             return bInfoLoaded;
  347.                         }
  348.                     }
  349.                 }
  350.             }
  351.             ::CloseHandle( hScsiDriveIOCTL );
  352.         }
  353.     }
  354.     return bInfoLoaded;
  355. }

  356. BOOL DoIdentify( HANDLE hPhysicalDriveIOCTL, PSENDCMDINPARAMS pSCIP,
  357.                  PSENDCMDOUTPARAMS pSCOP, BYTE bIDCmd, BYTE bDriveNum,
  358.                  PDWORD lpcbBytesReturned )
  359. {
  360.     // Set up data structures for IDENTIFY command.
  361.     pSCIP->cBufferSize                  = IDENTIFY_BUFFER_SIZE;
  362.     pSCIP->irDriveRegs.bFeaturesReg     = 0;
  363.     pSCIP->irDriveRegs.bSectorCountReg  = 1;
  364.     pSCIP->irDriveRegs.bSectorNumberReg = 1;
  365.     pSCIP->irDriveRegs.bCylLowReg       = 0;
  366.     pSCIP->irDriveRegs.bCylHighReg      = 0;
  367.      
  368.     // calc the drive number.
  369.     pSCIP->irDriveRegs.bDriveHeadReg = 0xA0 | ( ( bDriveNum & 1 ) << 4 );

  370.     // The command can either be IDE identify or ATAPI identify.
  371.     pSCIP->irDriveRegs.bCommandReg = bIDCmd;
  372.     pSCIP->bDriveNumber = bDriveNum;
  373.     pSCIP->cBufferSize = IDENTIFY_BUFFER_SIZE;
  374.      
  375.     return DeviceIoControl( hPhysicalDriveIOCTL, DFP_RECEIVE_DRIVE_DATA,
  376.         ( LPVOID ) pSCIP,
  377.         sizeof( SENDCMDINPARAMS ) - 1,
  378.         ( LPVOID ) pSCOP,
  379.         sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE - 1,
  380.         lpcbBytesReturned, NULL );
  381. }

  382. BOOL WinNTHDSerialNumAsPhysicalRead( BYTE* dwSerial, UINT* puSerialLen, UINT uMaxSerialLen )
  383. {
  384. #define  DFP_GET_VERSION          0x00074080
  385.     BOOL bInfoLoaded = FALSE;

  386.     for( UINT uDrive = 0; uDrive < 4; ++ uDrive )
  387.     {
  388.         HANDLE hPhysicalDriveIOCTL = 0;

  389.         //  Try to get a handle to PhysicalDrive IOCTL, report failure
  390.         //  and exit if can't.
  391.         char szDriveName [256];
  392.         sprintf( szDriveName, "<a>\\\\.\\PhysicalDrive%d</a>", uDrive );

  393.         //  Windows NT, Windows 2000, must have admin rights
  394.         hPhysicalDriveIOCTL = CreateFile( szDriveName,
  395.             GENERIC_READ | GENERIC_WRITE,
  396.             FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,
  397.             OPEN_EXISTING, 0, NULL);

  398.         if( hPhysicalDriveIOCTL != INVALID_HANDLE_VALUE )
  399.         {
  400.             GETVERSIONOUTPARAMS VersionParams = { 0 };
  401.             DWORD               cbBytesReturned = 0;

  402.             // Get the version, etc of PhysicalDrive IOCTL
  403.             if( DeviceIoControl( hPhysicalDriveIOCTL, DFP_GET_VERSION,
  404.                 NULL,
  405.                 0,
  406.                 &VersionParams,
  407.                 sizeof( GETVERSIONOUTPARAMS ),
  408.                 &cbBytesReturned, NULL ) )
  409.             {
  410.                 // If there is a IDE device at number "i" issue commands
  411.                 // to the device
  412.                 if( VersionParams.bIDEDeviceMap != 0 )
  413.                 {
  414.                     BYTE             bIDCmd = 0;   // IDE or ATAPI IDENTIFY cmd
  415.                     SENDCMDINPARAMS  scip = { 0 };

  416.                     // Now, get the ID sector for all IDE devices in the system.
  417.                     // If the device is ATAPI use the IDE_ATAPI_IDENTIFY command,
  418.                     // otherwise use the IDE_ATA_IDENTIFY command
  419.                     bIDCmd = ( VersionParams.bIDEDeviceMap >> uDrive & 0x10 ) ? IDE_ATAPI_IDENTIFY : IDE_ATA_IDENTIFY;
  420.                     BYTE IdOutCmd[sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE - 1] = { 0 };

  421.                     if( DoIdentify( hPhysicalDriveIOCTL,
  422.                         &scip,
  423.                         ( PSENDCMDOUTPARAMS )&IdOutCmd,
  424.                         ( BYTE )bIDCmd,
  425.                         ( BYTE )uDrive,
  426.                         &cbBytesReturned ) )
  427.                     {
  428.                         if( * puSerialLen + 20U <= uMaxSerialLen )
  429.                         {
  430.                             CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )( ( ( PSENDCMDOUTPARAMS )IdOutCmd )->bBuffer ) ) + 10, 20 );  // 序列号

  431.                             // Cut off the trailing blanks
  432.                             for( UINT i = 20; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )  {}
  433.                             * puSerialLen += i;

  434.                             CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )( ( ( PSENDCMDOUTPARAMS )IdOutCmd )->bBuffer ) ) + 27, 40 ); // 型号

  435.                             // Cut off the trailing blanks
  436.                             for( i = 40; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )  {}
  437.                             * puSerialLen += i;

  438.                             bInfoLoaded = TRUE;
  439.                         }
  440.                         else
  441.                         {
  442.                             ::CloseHandle( hPhysicalDriveIOCTL );
  443.                             return bInfoLoaded;
  444.                         }
  445.                     }
  446.                 }
  447.             }
  448.             CloseHandle( hPhysicalDriveIOCTL );
  449.         }
  450.     }
  451.     return bInfoLoaded;
  452. }

  453. UINT FindAwardBios( BYTE** ppBiosAddr )
  454. {
  455.     BYTE* pBiosAddr = * ppBiosAddr + 0xEC71;

  456.     BYTE szBiosData[128];
  457.     CopyMemory( szBiosData, pBiosAddr, 127 );
  458.     szBiosData[127] = 0;
  459.      
  460.     int iLen = lstrlen( ( char* )szBiosData );
  461.     if( iLen > 0 && iLen < 128 )
  462.     {
  463.         //AWard:         07/08/2002-i845G-ITE8712-JF69VD0CC-00
  464.         //Phoenix-Award: 03/12/2002-sis645-p4s333
  465.         if( szBiosData[2] == '/' && szBiosData[5] == '/' )
  466.         {
  467.             BYTE* p = szBiosData;
  468.             while( * p )
  469.             {
  470.                 if( * p < ' ' || * p >= 127 )
  471.                 {
  472.                     break;
  473.                 }
  474.                 ++ p;
  475.             }
  476.             if( * p == 0 )
  477.             {
  478.                 * ppBiosAddr = pBiosAddr;
  479.                 return ( UINT )iLen;
  480.             }
  481.         }
  482.     }
  483.     return 0;
  484. }

  485. UINT FindAmiBios( BYTE** ppBiosAddr )
  486. {
  487.     BYTE* pBiosAddr = * ppBiosAddr + 0xF478;
  488.      
  489.     BYTE szBiosData[128];
  490.     CopyMemory( szBiosData, pBiosAddr, 127 );
  491.     szBiosData[127] = 0;
  492.      
  493.     int iLen = lstrlen( ( char* )szBiosData );
  494.     if( iLen > 0 && iLen < 128 )
  495.     {
  496.         // Example: "AMI: 51-2300-000000-00101111-030199-"
  497.         if( szBiosData[2] == '-' && szBiosData[7] == '-' )
  498.         {
  499.             BYTE* p = szBiosData;
  500.             while( * p )
  501.             {
  502.                 if( * p < ' ' || * p >= 127 )
  503.                 {
  504.                     break;
  505.                 }
  506.                 ++ p;
  507.             }
  508.             if( * p == 0 )
  509.             {
  510.                 * ppBiosAddr = pBiosAddr;
  511.                 return ( UINT )iLen;
  512.             }
  513.         }
  514.     }
  515.     return 0;
  516. }

  517. UINT FindPhoenixBios( BYTE** ppBiosAddr )
  518. {
  519.     UINT uOffset[3] = { 0x6577, 0x7196, 0x7550 };
  520.     for( UINT i = 0; i < 3; ++ i )
  521.     {
  522.         BYTE* pBiosAddr = * ppBiosAddr + uOffset[i];

  523.         BYTE szBiosData[128];
  524.         CopyMemory( szBiosData, pBiosAddr, 127 );
  525.         szBiosData[127] = 0;

  526.         int iLen = lstrlen( ( char* )szBiosData );
  527.         if( iLen > 0 && iLen < 128 )
  528.         {
  529.             // Example: Phoenix "NITELT0.86B.0044.P11.9910111055"
  530.             if( szBiosData[7] == '.' && szBiosData[11] == '.' )
  531.             {
  532.                 BYTE* p = szBiosData;
  533.                 while( * p )
  534.                 {
  535.                     if( * p < ' ' || * p >= 127 )
  536.                     {
  537.                         break;
  538.                     }
  539.                     ++ p;
  540.                 }
  541.                 if( * p == 0 )
  542.                 {
  543.                     * ppBiosAddr = pBiosAddr;
  544.                     return ( UINT )iLen;
  545.                 }
  546.             }
  547.         }
  548.     }
  549.     return 0;
  550. }</p>
复制代码



联系我时,请说是在 挂海论坛 上看到的,谢谢!



上一篇:进程句柄查看工具(File,Event,Mutant,Section等句柄)
下一篇:21天学会C++视频教程-下载高清
免责声明:
1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关。一切关于该内容及资源商业行为与www.52ghai.com无关。

2、本站提供的一切资源内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。

3、本站信息来自第三方用户,非本站自制,版权归原作者享有,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。

4、如果您喜欢该程序,请支持正版,购买注册,得到更好的正版服务。如有侵犯你版权的,请邮件与我们联系删除(邮箱:[email protected]),本站将立即改正。

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【好评】和【海币】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
3正式会员
253/300

253

积分

143

主题

2

听众
已帮网友解决0 个问题
好评
0
贡献
110
海币
1187
交易币
0
沙发
发表于 2014-7-26 09:24:36 | 只看该作者
淡定,淡定,淡定……

3

积分

3

主题

0

听众
已帮网友解决0 个问题
好评
0
贡献
0
海币
629
交易币
0
板凳
发表于 2014-8-13 14:48:09 | 只看该作者
路过,顺便支持一下..

2

积分

1

主题

0

听众
已帮网友解决0 个问题
好评
0
贡献
1
海币
912
交易币
0
地板
发表于 2014-8-31 21:47:04 | 只看该作者
我来顶你~~

26

积分

13

主题

2

听众
已帮网友解决0 个问题
好评
0
贡献
13
海币
140
交易币
0
5#
发表于 2014-9-16 10:33:52 | 只看该作者
来刷分的,hehe
4中级会员
338/600

338

积分

112

主题

3

听众
已帮网友解决0 个问题
好评
0
贡献
226
海币
2949
交易币
0
6#
发表于 2014-9-29 16:58:31 | 只看该作者
过来看看的
4中级会员
536/600

536

积分

165

主题

7

听众
已帮网友解决0 个问题
好评
0
贡献
371
海币
3255
交易币
0
7#
发表于 2014-10-12 16:01:16 | 只看该作者
不知该说些什么。。。。。。
3正式会员
112/300

112

积分

50

主题

1

听众
已帮网友解决0 个问题
好评
0
贡献
62
海币
1667
交易币
0
8#
发表于 2014-12-31 08:25:46 | 只看该作者
支持,楼下的跟上哈~

98

积分

58

主题

6

听众
已帮网友解决0 个问题
好评
0
贡献
40
海币
3466
交易币
50
9#
发表于 2015-1-3 18:53:01 | 只看该作者
LZ是天才,坚定完毕

57

积分

14

主题

2

听众
已帮网友解决0 个问题
好评
0
贡献
43
海币
940
交易币
0
10#
发表于 2015-1-4 10:57:24 | 只看该作者
真是难得给力的帖子啊。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

免责声明|Archiver|手机版|小黑屋|挂海论坛

GMT+8, 2024-4-27 07:27 , Processed in 0.488853 second(s), 37 queries , Gzip On.

Powered by Discuz! X3.2

本站资源来自互联网用户收集发布,如有侵权请邮件与我们联系处理。xhzlw@foxmail.com

快速回复 返回顶部 返回列表