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

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

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

// 网卡 MAC 地址,注意: MAC 地址是可以在注册表中修改的

{

UINT uErrorCode=0;

IP_ADAPTER_INFO iai;

ULONG uSize = 0;

DWORD dwResult = GetAdaptersInfo( &iai, &uSize );

if( dwResult == ERROR_BUFFER_OVERFLOW )

{

IP_ADAPTER_INFO* piai=( IP_ADAPTER_INFO* )HeapAlloc( GetProcessHeap( ), 0, uSize );

if( piai != NULL )

{

dwResult = GetAdaptersInfo( piai, &uSize );

if( ERROR_SUCCESS == dwResult )

{

IP_ADAPTER_INFO* piai2 = piai;

while(piai2!=NULL &&(uSystemInfoLen+piai2->AddressLength )< 4096U)

{

CopyMemory(szSystemInfo+uSystemInfoLen,piai2->Address, piai2->AddressLength );

uSystemInfoLen += piai2->AddressLength;

piai2 = piai2->Next;

}

}

else

{

uErrorCode = 0xF0000000U + dwResult;

}

VERIFY( HeapFree( GetProcessHeap( ), 0, piai ) );

}

else

{

return FALSE;

}

}

else

{

uErrorCode = 0xE0000000U + dwResult;

}

if( uErrorCode != 0U )

{

return FALSE;

}

}

// 硬盘序列号,注意:有的硬盘没有序列号

{

OSVERSIONINFO ovi = { 0 };

ovi.dwOSVersionInfoSize = sizeof( OSVERSIONINFO );

GetVersionEx( &ovi );

if( ovi.dwPlatformId != VER_PLATFORM_WIN32_NT )

{

// Only Windows 2000, Windows XP, Windows Server 2003...

return FALSE;

}

else

{

if( !WinNTHDSerialNumAsPhysicalRead( szSystemInfo, &uSystemInfoLen, 1024 ) )

{

WinNTHDSerialNumAsScsiRead( szSystemInfo, &uSystemInfoLen, 1024 );

}

}

}

// CPU ID

{

BOOL bException = FALSE;

BYTE szCpu[16]  = { 0 };

UINT uCpuID     = 0U;

__try

{

_asm

{

mov eax, 0

cpuid

mov dword ptr szCpu[0], ebx

mov dword ptr szCpu[4], edx

mov dword ptr szCpu[8], ecx

mov eax, 1

cpuid

mov uCpuID, edx

}

}

__except( EXCEPTION_EXECUTE_HANDLER )

{

bException = TRUE;

}

if( !bException )

{

CopyMemory( szSystemInfo + uSystemInfoLen, &uCpuID, sizeof( UINT ) );

uSystemInfoLen += sizeof( UINT );

uCpuID = strlen( ( char* )szCpu );

CopyMemory( szSystemInfo + uSystemInfoLen, szCpu, uCpuID );

uSystemInfoLen += uCpuID;

}

}

// BIOS 编号,支持 AMI, AWARD, PHOENIX

{

SIZE_T ssize;

LARGE_INTEGER so;

so.LowPart=0x000f0000;

so.HighPart=0x00000000;

ssize=0xffff;

wchar_t strPH[30]=L\\device\\physicalmemory;

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=&struniph;

obj_ar.RootDirectory=0;

obj_ar.SecurityDescriptor=0;

obj_ar.SecurityQualityOfService =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(&hSection,4,&obj_ar) &&

0 == ZWmapV(

( HANDLE )hSection,   //打开Section时得到的句柄

( HANDLE )0xFFFFFFFF, //将要映射进程的句柄,

&ba,                  //映射的基址

0,

0xFFFF,               //分配的大小

&so,                  //物理内存的地址

&ssize,               //指向读取内存块大小的指针

1,                    //子进程的可继承性设定

0,                    //分配类型

2                     //保护类型

) )

//执行后会在当前进程的空间开辟一段64k的空间,并把f000:0000到f000:ffff处的内容映射到这里

//映射的基址由ba返回,如果映射不再有用,应该用ZwUnmapViewOfSection断开映射

{

BYTE* pBiosSerial = ( BYTE* )ba;

UINT uBiosSerialLen = FindAwardBios( &pBiosSerial );

if( uBiosSerialLen == 0U )

{

uBiosSerialLen = FindAmiBios( &pBiosSerial );

if( uBiosSerialLen == 0U )

{

uBiosSerialLen = FindPhoenixBios( &pBiosSerial );

}

}

if( uBiosSerialLen != 0U )

{

CopyMemory( szSystemInfo + uSystemInfoLen, pBiosSerial, uBiosSerialLen );

uSystemInfoLen += uBiosSerialLen;

}

ZWunmapV( ( HANDLE )0xFFFFFFFF, ( void* )ba );

}

}

// 完毕, 系统特征码已取得。

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

#define  FILE_DEVICE_SCSI              0x0000001b

#define  IOCTL_SCSI_MINIPORT_IDENTIFY  ( ( FILE_DEVICE_SCSI << 16 ) + 0x0501 )

#define  IOCTL_SCSI_MINIPORT 0x0004D008

#define  IDENTIFY_BUFFER_SIZE  512

#define  SENDIDLENGTH  ( sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE )

#define  IDE_ATAPI_IDENTIFY  0xA1  //  Returns ID sector for ATAPI.

#define  IDE_ATA_IDENTIFY    0xEC  //  Returns ID sector for ATA.

#define  DFP_RECEIVE_DRIVE_DATA   0x0007c088

typedef struct _IDSECTOR

{

USHORT  wGenConfig;

USHORT  wNumCyls;

USHORT  wReserved;

USHORT  wNumHeads;

USHORT  wBytesPerTrack;

USHORT  wBytesPerSector;

USHORT  wSectorsPerTrack;

USHORT  wVendorUnique[3];

CHAR    sSerialNumber[20];

USHORT  wBufferType;

USHORT  wBufferSize;

USHORT  wECCSize;

CHAR    sFirmwareRev[8];

CHAR    sModelNumber[40];

USHORT  wMoreVendorUnique;

USHORT  wDoubleWordIO;

USHORT  wCapabilities;

USHORT  wReserved1;

USHORT  wPIOTiming;

USHORT  wDMATiming;

USHORT  wBS;

USHORT  wNumCurrentCyls;

USHORT  wNumCurrentHeads;

USHORT  wNumCurrentSectorsPerTrack;

ULONG   ulCurrentSectorCapacity;

USHORT  wMultSectorStuff;

ULONG   ulTotalAddressableSectors;

USHORT  wSingleWordDMA;

USHORT  wMultiWordDMA;

BYTE    bReserved[128];

} IDSECTOR, *PIDSECTOR;

typedef struct _DRIVERSTATUS

{

BYTE  bDriverError;  //  Error code from driver, or 0 if no error.

BYTE  bIDEStatus;    //  Contents of IDE Error register.

//  Only valid when bDriverError is SMART_IDE_ERROR.

BYTE  bReserved[2];  //  Reserved for future expansion.

DWORD  dwReserved[2];  //  Reserved for future expansion.

} DRIVERSTATUS, *PDRIVERSTATUS, *LPDRIVERSTATUS;

typedef struct _SENDCMDOUTPARAMS

{

DWORD         cBufferSize;   //  Size of bBuffer in bytes

DRIVERSTATUS  DriverStatus;  //  Driver status structure.

BYTE          bBuffer[1];    //  Buffer of arbitrary length in which to store the data read from the                                                       // drive.

} SENDCMDOUTPARAMS, *PSENDCMDOUTPARAMS, *LPSENDCMDOUTPARAMS;

typedef struct _SRB_IO_CONTROL

{

ULONG HeaderLength;

UCHAR Signature[8];

ULONG Timeout;

ULONG ControlCode;

ULONG ReturnCode;

ULONG Length;

} SRB_IO_CONTROL, *PSRB_IO_CONTROL;

typedef struct _IDEREGS

{

BYTE bFeaturesReg;       // Used for specifying SMART "commands".

BYTE bSectorCountReg;    // IDE sector count register

BYTE bSectorNumberReg;   // IDE sector number register

BYTE bCylLowReg;         // IDE low order cylinder value

BYTE bCylHighReg;        // IDE high order cylinder value

BYTE bDriveHeadReg;      // IDE drive/head register

BYTE bCommandReg;        // Actual IDE command.

BYTE bReserved;          // reserved for future use.  Must be zero.

} IDEREGS, *PIDEREGS, *LPIDEREGS;

typedef struct _SENDCMDINPARAMS

{

DWORD     cBufferSize;   //  Buffer size in bytes

IDEREGS   irDriveRegs;   //  Structure with drive register values.

BYTE bDriveNumber;       //  Physical drive number to send

//  command to (0,1,2,3).

BYTE bReserved[3];       //  Reserved for future expansion.

DWORD     dwReserved[4]; //  For future use.

BYTE      bBuffer[1];    //  Input buffer.

} SENDCMDINPARAMS, *PSENDCMDINPARAMS, *LPSENDCMDINPARAMS;

typedef struct _GETVERSIONOUTPARAMS

{

BYTE bVersion;      // Binary driver version.

BYTE bRevision;     // Binary driver revision.

BYTE bReserved;     // Not used.

BYTE bIDEDeviceMap; // Bit map of IDE devices.

DWORD fCapabilities; // Bit mask of driver capabilities.

DWORD dwReserved[4]; // For future use.

} GETVERSIONOUTPARAMS, *PGETVERSIONOUTPARAMS, *LPGETVERSIONOUTPARAMS;

//////////////////////////////////////////////////////////////////////

//结构定义

typedef struct _UNICODE_STRING

{

USHORT  Length;//长度

USHORT  MaximumLength;//最大长度

PWSTR  Buffer;//缓存指针

} UNICODE_STRING,*PUNICODE_STRING;

typedef struct _OBJECT_ATTRIBUTES

{

ULONG Length;//长度 18h

HANDLE RootDirectory;//  00000000

PUNICODE_STRING ObjectName;//指向对象名的指针

ULONG Attributes;//对象属性00000040h

PVOID SecurityDescriptor;        // Points to type SECURITY_DESCRIPTOR,0

PVOID SecurityQualityOfService;  // Points to type SECURITY_QUALITY_OF_SERVICE,0

} OBJECT_ATTRIBUTES;

typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;

//函数指针变量类型

typedef DWORD  (__stdcall *ZWOS )( PHANDLE,ACCESS_MASK,POBJECT_ATTRIBUTES);

typedef DWORD  (__stdcall *ZWMV )( HANDLE,HANDLE,PVOID,ULONG,ULONG,PLARGE_INTEGER,PSIZE_T,DWORD,ULONG,ULONG);

typedef DWORD  (__stdcall *ZWUMV )( HANDLE,PVOID);

BOOL WinNTHDSerialNumAsScsiRead( BYTE* dwSerial, UINT* puSerialLen, UINT uMaxSerialLen )

{

BOOL bInfoLoaded = FALSE;

for( int iController = 0; iController < 2; ++ iController )

{

HANDLE hScsiDriveIOCTL = 0;

char   szDriveName[256];

//  Try to get a handle to PhysicalDrive IOCTL, report failure

//  and exit if can't.

sprintf( szDriveName, "\\\\.\\Scsi%d:", iController );

//  Windows NT, Windows 2000, any rights should do

hScsiDriveIOCTL = CreateFile( szDriveName,

GENERIC_READ | GENERIC_WRITE,

FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,

OPEN_EXISTING, 0, NULL);

// if (hScsiDriveIOCTL == INVALID_HANDLE_VALUE)

//    printf ("Unable to open SCSI controller %d, error code: 0x%lX\n",

//            controller, GetLastError ());

if( hScsiDriveIOCTL != INVALID_HANDLE_VALUE )

{

int iDrive = 0;

for( iDrive = 0; iDrive < 2; ++ iDrive )

{

char szBuffer[sizeof( SRB_IO_CONTROL ) + SENDIDLENGTH] = { 0 };

SRB_IO_CONTROL* p = ( SRB_IO_CONTROL* )szBuffer;

SENDCMDINPARAMS* pin = ( SENDCMDINPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );

DWORD dwResult; http://www.it55.com/

p->HeaderLength = sizeof( SRB_IO_CONTROL );

p->Timeout = 10000;

p->Length = SENDIDLENGTH;

p->ControlCode = 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_IO_CONTROL ) + SENDIDLENGTH, IT资讯之家 http://www.it55.com

&dwResult, NULL ) )

{

SENDCMDOUTPARAMS* pOut = ( SENDCMDOUTPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );

IDSECTOR* pId = ( IDSECTOR* )( pOut->bBuffer );

if( pId->sModelNumber[0] )

{

if( * puSerialLen + 20U <= uMaxSerialLen )

{

// 序列号

CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )pId ) + 10, 20 );

// Cut off the trailing blanks

for( UINT i = 20; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )

{}

* puSerialLen += i;

// 型号

CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )pId ) + 27, 40 );

// Cut off the trailing blanks

for( i = 40; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )

{}

* puSerialLen += i; it55.com

bInfoLoaded = TRUE;

}

else

{

::CloseHandle( hScsiDriveIOCTL );

return bInfoLoaded;

}

}

}

}

::CloseHandle( hScsiDriveIOCTL );

}

}

return bInfoLoaded;

}

BOOL DoIdentify( HANDLE hPhysicalDriveIOCTL, PSENDCMDINPARAMS pSCIP,

PSENDCMDOUTPARAMS pSCOP, BYTE bIDCmd, BYTE bDriveNum,

PDWORD lpcbBytesReturned )

{

// Set up data structures for IDENTIFY command.

pSCIP->cBufferSize                  = IDENTIFY_BUFFER_SIZE;

pSCIP->irDriveRegs.bFeaturesReg     = 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 & 1 ) << 4 );

// The command can either be IDE identify or ATAPI identify.

pSCIP->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_GET_VERSION          0x00074080

BOOL bInfoLoaded = FALSE;

for( UINT uDrive = 0; uDrive < 4; ++ uDrive )

{

HANDLE hPhysicalDriveIOCTL = 0;

//  Try to get a handle to PhysicalDrive IOCTL, report failure

//  and exit if can't.

char szDriveName [256];

sprintf( szDriveName, "\\\\.\\PhysicalDrive%d", uDrive );

//  Windows NT, Windows 2000, must have admin rights

hPhysicalDriveIOCTL = CreateFile( szDriveName,

GENERIC_READ | GENERIC_WRITE,

FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, NULL);

if( hPhysicalDriveIOCTL != INVALID_HANDLE_VALUE )

{

GETVERSIONOUTPARAMS VersionParams = { 0 };

DWORD               cbBytesReturned = 0;

// Get the version, etc of PhysicalDrive IOCTL

if( DeviceIoControl( hPhysicalDriveIOCTL, DFP_GET_VERSION,

NULL,

0,

&VersionParams,

sizeof( GETVERSIONOUTPARAMS ),

&cbBytesReturned, NULL ) )

{

// If there is a IDE device at number "i" issue commands

// to the device

if( VersionParams.bIDEDeviceMap != 0 )

{

BYTE             bIDCmd = 0;   // IDE or ATAPI IDENTIFY cmd

SENDCMDINPARAMS  scip = { 0 };

// Now, get the ID sector for all IDE devices in the system.

// If the device is ATAPI use the IDE_ATAPI_IDENTIFY command,

// otherwise use the IDE_ATA_IDENTIFY command

bIDCmd = ( VersionParams.bIDEDeviceMap >> uDrive & 0x10 ) ? IDE_ATAPI_IDENTIFY : IDE_ATA_IDENTIFY;

BYTE IdOutCmd[sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE - 1] = { 0 };

if( DoIdentify( hPhysicalDriveIOCTL,

&scip,

( PSENDCMDOUTPARAMS )&IdOutCmd,

( BYTE )bIDCmd,

( BYTE )uDrive,

&cbBytesReturned ) )

{  if( * puSerialLen + 20U <= uMaxSerialLen )

{

CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )( ( ( PSENDCMDOUTPARAMS )IdOutCmd )->bBuffer ) ) + 10, 20 );  // 序列号

// Cut off the trailing blanks

for( UINT i = 20; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )  {}

* puSerialLen += i;

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

// Cut off the trailing blanks

for( i = 40; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )  {}

* puSerialLen += i;

bInfoLoaded = TRUE;

}

else

{

::CloseHandle( hPhysicalDriveIOCTL );

return bInfoLoaded;

}

}

}

}

CloseHandle( hPhysicalDriveIOCTL );

}

}

return bInfoLoaded;

}

UINT FindAwardBios( BYTE** ppBiosAddr )

{

BYTE* pBiosAddr = * ppBiosAddr + 0xEC71;

BYTE szBiosData[128];

CopyMemory( szBiosData, pBiosAddr, 127 );

szBiosData[127] = 0;

int iLen = lstrlen( ( char* )szBiosData );

if( iLen > 0 && iLen < 128 )

{

//AWard:         07/08/2002-i845G-ITE8712-JF69VD0CC-00

//Phoenix-Award: 03/12/2002-sis645-p4s333

if( szBiosData[2] == '/' && szBiosData[5] == '/' )

{

BYTE* p = szBiosData;

while( * p )

{

if( * p < ' ' || * p >= 127 )

{

break;

}

++ p;

}

if( * p == 0 )

{

* ppBiosAddr = pBiosAddr;

return ( UINT )iLen;

}

}

}

return 0;

}

UINT FindAmiBios( BYTE** ppBiosAddr )

{

BYTE* pBiosAddr = * ppBiosAddr + 0xF478;

BYTE szBiosData[128];

CopyMemory( szBiosData, pBiosAddr, 127 );

szBiosData[127] = 0;

int iLen = lstrlen( ( char* )szBiosData );

if( iLen > 0 && iLen < 128 )

{

// Example: "AMI: 51-2300-000000-00101111-030199-"

if( szBiosData[2] == '-' && szBiosData[7] == '-' )

{

BYTE* p = szBiosData;

while( * p )

{

if( * p < ' ' || * p >= 127 )

{

break;

}

++ p;

}

if( * p == 0 )

{

* ppBiosAddr = pBiosAddr;

return ( UINT )iLen;

}

}

}

return 0;

}

UINT FindPhoenixBios( BYTE** ppBiosAddr )

{

UINT uOffset[3] = { 0x6577, 0x7196, 0x7550 };

for( UINT i = 0; i < 3; ++ i )

{

BYTE* pBiosAddr = * ppBiosAddr + uOffset[i];

BYTE szBiosData[128];

CopyMemory( szBiosData, pBiosAddr, 127 );

szBiosData[127] = 0;

int iLen = lstrlen( ( char* )szBiosData );

if( iLen > 0 && iLen < 128 )

{

// Example: Phoenix "NITELT0.86B.0044.P11.9910111055"

if( szBiosData[7] == '.' && szBiosData[11] == '.' )

{

BYTE* p = szBiosData;

while( * p )

{

if( * p < ' ' || * p >= 127 )

{

break;

}

++ p;

}

if( * p == 0 )

{

* ppBiosAddr = pBiosAddr;

return ( UINT )iLen;

}

}

}

}

return 0;

}

VC++获取网卡MAC、硬盘序列号、CPU ID、BIOS编号的更多相关文章

  1. 转: 通过WMI获取网卡MAC地址、硬盘序列号、主板序列号、CPU ID、BIOS序列号

    最近由于项目的需要,需要在程序中获取机器的硬盘序列号和MAC地址等信息,在C#下,可以很容易的获得这些信息,但是在C++程序中感觉比较麻烦.经过百度,发现很多大虾都是通过WMI来获取这些硬件信息的,网 ...

  2. (转)通过WMI获取网卡MAC地址、硬盘序列号、主板序列号、CPU ID、BIOS序列号

    最近由于项目的需要,需要在程序中获取机器的硬盘序列号和MAC地址等信息,在C#下,可以很容易的获得这些信息,但是在C++程序中感觉比较麻烦.经过百度,发现很多大虾都是通过WMI来获取这些硬件信息的,网 ...

  3. 获取网卡MAC、硬盘序列号、CPU_ID、BIOS编号

    抄来的 获取网卡MAC.硬盘序列号.CPU ID.BIOS编号 本文中所有原理及思想均取自网络,有修改.其中获取硬盘序列号.获取CPU编号.获取BIOS编号的原始代码的著作权归各自作者所有. 以下代码 ...

  4. Python 获取 网卡 MAC 地址

    /*********************************************************************** * Python 获取 网卡 MAC 地址 * 说明: ...

  5. windows平台下获取网卡MAC地址、硬盘序列号、主板序列号、CPU ID、BIOS序列号

    转自http://blog.csdn.net/jhqin/article/details/5548656,如有侵权,请联系本人删除,谢谢!! 头文件:WMI_DeviceQuery.h /* ---- ...

  6. 通过WMI获取网卡MAC地址、硬盘序列号、主板序列号、CPU ID、BIOS序列号

    转载:https://www.cnblogs.com/tlduck/p/5132738.html #define _WIN32_DCOM #include<iostream> #inclu ...

  7. C#获取电脑硬件信息(CPU ID、主板ID、硬盘ID、BIOS编号)

    最近学习过程中,想到提取系统硬件信息做一些验证,故而对网上提到的利用.NET System.Management类获取硬件信息做了进一步的学习.验证.验证是分别在4台电脑,XP SP3系统中进行,特将 ...

  8. 关于使用java执行shell脚本获取centos的硬盘序列号和mac地址

    1.获取硬盘序列号: 新建shell脚本文件: identifier.sh, 内容为: diskdata=`fdisk -l` diskleft=${diskdata#*"identifie ...

  9. php获取网卡MAC地址源码

    <?php /** 获取网卡的MAC地址原码:目前支持WIN/LINUX系统 获取机器网卡的物理(MAC)地址 **/ class GetMacAddr{ var $return_array = ...

随机推荐

  1. 移动平台3G手机网站前端开发布局技巧汇总

    移动平台3G手机网站前端开发布局技巧汇总 作者:前端开发-武方博   发布:2011-05-10 09:11   分类:移动开发   阅读:120,618 views   7条评论     您或许正在 ...

  2. web版扫雷小游戏(二)

    接上篇~~第一次写这种技术博客,发现把自己做的东西介绍出来还是一件脑力活,不是那么轻松啊,好吧,想到哪写到哪,流水记录之,待完成之后再根据大家的意见进行修改吧. 游戏实现 根据对扫雷游戏的体验和分析, ...

  3. 功能: 用函数 funName 对数组 objArray 中的每个值进行处理一次,

    function each( objArray, funName ) {//功能: 用函数 funName 对数组 objArray 中的每个值进行处理一次,for(var i=0; i<obj ...

  4. shell脚本获取mysql插入数据自增长id的值

    shell脚本获取mysql插入数据自增长id的值 在shell脚本中我们可以通过last_insert_id()获取id值,但是,需要注意的是,该函数必须在执行插入操作的sql语句之后,立即调用,否 ...

  5. 关于 self 和 super 在oc 中 的疑惑 与 分析

    关于 self 和 super 在oc 中 的疑惑 与 分析   面试一定都是很注重 基础的,不管高级还是初级. 虽然基础好跟基础不好都可以写 代码,网上那么多资料.  区分高低也就是研究的深度和广度 ...

  6. 阻止文件不被上传到iCloud-b

    有空用下 http://www.cocoachina.com/bbs/read.php?tid=86244 http://www.ooso.net/archives/617 http://blog.c ...

  7. iOS判断手机中是否 有 SIM卡---备用

    [CTSIMSupportGetSIMStatus() isEqualToString:kCTSIMSupportSIMStatusNotInserted]可以判断是否插入了sim卡. 前提是把下面的 ...

  8. Python 字典 Print 格式化

    __author__ = 'dell' ab = {'Swaroop': 'swaroopch@byteofpython.info', 'Larry': 'larry@wall.org', 'Mats ...

  9. js singleton

    方案一:利用闭包的两个作用,可以变通地读到内部的变量. 方案二: 是可以让这些变量始终在内存中. 方案一 var SingletonTester = (function () { //单例方法 fun ...

  10. Unity3D 3D横版跑酷

    Unity3d  3D横版跑酷系列(Character Controller组件) @广州小龙 目前在做一个3D跑酷的横版游戏,目前说一下 Character Controller组件! 1.Slop ...