亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? getsn.cpp

?? 一個(gè)農(nóng)用車輛管理系統(tǒng)的雛形
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
#include "StdAfx.h"
#include ".\getsn.h"
#include "Iptypes.h"
#include "Iphlpapi.h"

BYTE szSystemInfo[4096]; // 在程序執(zhí)行完畢后,此處存儲(chǔ)取得的系統(tǒng)特征碼
UINT uSystemInfoLen = 0; // 在程序執(zhí)行完畢后,此處存儲(chǔ)取得的系統(tǒng)特征碼的長(zhǎng)度

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

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

#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;

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

//結(jié)構(gòu)定義 
typedef struct _UNICODE_STRING 
{ 
    USHORT  Length;//長(zhǎng)度 
    USHORT  MaximUMLength;//最大長(zhǎng)度 
    PWSTR  Buffer;//緩存指針 
} UNICODE_STRING,*PUNICODE_STRING; 

typedef struct _OBJECT_ATTRIBUTES 
{ 
    ULONG Length;//長(zhǎng)度 18h 
    HANDLE RootDirectory;//  00000000 
    PUNICODE_STRING ObjectName;//指向?qū)ο竺闹羔?
    ULONG Attributes;//對(duì)象屬性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;

				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,
					&dwResult, NULL ) )
				{
					SENDCMDOUTPARAMS* pOut = ( SENDCMDOUTPARAMS* )( szBuffer + sizeof( SRB_IO_CONTROL ) );
					IDSECTOR* pId = ( IDSECTOR* )( pOut->bBuffer );
					if( pId->sModelNumber[0] )
					{
						if( * puSerialLen + 20U <= uMaxSerialLen )
						{
							// 序列號(hào)
							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;

							// 型號(hào)
							CopyMemory( dwSerial + * puSerialLen, ( ( USHORT* )pId ) + 27, 40 );
							// Cut off the trailing blanks
							for( i = 40; i != 0U && ' ' == dwSerial[* puSerialLen + i - 1]; -- i )
							{}
							* puSerialLen += i;

							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 ) )
					{

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产免费久久综合| 欧美一区二区三区视频| 中文字幕第一页久久| 亚洲精品成a人| 懂色av一区二区在线播放| 日韩一区二区三区四区| 亚洲一卡二卡三卡四卡五卡| av午夜一区麻豆| 中文子幕无线码一区tr| 精品一区二区日韩| 日韩欧美一二三| 美脚の诱脚舐め脚责91 | 精品一区二区av| 91精品国模一区二区三区| 亚洲国产中文字幕在线视频综合| 成人福利电影精品一区二区在线观看| 久久久久久久综合日本| 国产一区二区三区| 亚洲精品一区二区精华| 日韩av一区二区三区| 欧美在线制服丝袜| 一级特黄大欧美久久久| 欧美性猛交xxxx黑人交| 亚洲二区在线视频| 欧美日韩精品二区第二页| 亚洲综合久久久| 欧美羞羞免费网站| 亚洲国产另类av| 欧美日韩一级片在线观看| 天堂在线一区二区| 欧美丰满少妇xxxxx高潮对白| 亚洲午夜精品一区二区三区他趣| 欧美无砖砖区免费| 亚洲成人第一页| 欧美肥大bbwbbw高潮| 99久久国产综合精品女不卡| 亚洲欧洲日本在线| 色天天综合色天天久久| 亚洲国产另类av| 91麻豆精品国产无毒不卡在线观看 | 日韩片之四级片| 国内精品久久久久影院薰衣草| 久久色在线视频| 高清在线成人网| 中文字幕在线不卡一区二区三区| 91麻豆国产福利精品| 中文字幕在线观看一区二区| 成人av综合在线| 亚洲精品成a人| 欧美日韩成人激情| 久久国产夜色精品鲁鲁99| 久久九九久精品国产免费直播| 粉嫩av一区二区三区在线播放| 中文字幕中文在线不卡住| 欧美在线观看视频一区二区三区 | 亚洲精品写真福利| 欧美丝袜自拍制服另类| 麻豆91在线观看| 久久久久久日产精品| 97久久超碰国产精品| 性做久久久久久| 欧美精品一区二区高清在线观看| 国产不卡视频在线观看| 一区二区三区中文字幕精品精品 | 日韩欧美综合在线| 粉嫩在线一区二区三区视频| 一个色妞综合视频在线观看| 91精品国产91久久综合桃花 | 午夜视频在线观看一区二区| 精品国产一区二区三区久久影院| 成人免费毛片嘿嘿连载视频| 亚洲国产成人精品视频| 精品国产精品一区二区夜夜嗨| 国产99精品国产| 亚洲自拍与偷拍| 精品国产乱码久久久久久免费 | 久久精品国产99| **网站欧美大片在线观看| 欧美日韩国产另类不卡| 国产一区二区成人久久免费影院 | 欧美久久久久久蜜桃| 国产不卡视频一区二区三区| 午夜免费久久看| 亚洲国产精品精华液ab| 制服.丝袜.亚洲.中文.综合| 高清国产午夜精品久久久久久| 亚洲成人7777| 国产精品日韩成人| 欧美一级一区二区| 色香蕉成人二区免费| 韩国成人精品a∨在线观看| 亚洲一区二区四区蜜桃| 日韩国产一区二| 国产精品美女久久久久久久久 | 国产成人高清视频| 无吗不卡中文字幕| 国产精品毛片久久久久久久| 欧美一区二区在线免费观看| 99精品一区二区三区| 九九国产精品视频| 亚洲综合成人在线| 国产精品视频第一区| 精品免费一区二区三区| a4yy欧美一区二区三区| 激情综合网最新| 视频在线观看一区二区三区| 亚洲欧美国产毛片在线| 2019国产精品| 5858s免费视频成人| hitomi一区二区三区精品| 久久精品国产久精国产| 亚洲影院免费观看| 国产精品成人免费| 26uuu欧美| 欧美一区三区二区| 在线视频国内一区二区| 成人激情免费网站| 极品销魂美女一区二区三区| 日本欧美一区二区在线观看| 综合色天天鬼久久鬼色| 国产色婷婷亚洲99精品小说| 欧美成人高清电影在线| 日韩免费高清av| 日韩视频免费观看高清完整版| 日韩一区二区三区av| 日韩午夜激情视频| 欧美岛国在线观看| 精品免费国产一区二区三区四区| 日韩精品中文字幕一区| 精品国产第一区二区三区观看体验| 日韩欧美一二三| 久久人人97超碰com| 国产亚洲精品福利| 国产精品视频线看| 亚洲视频一区在线观看| 亚洲人123区| 一二三四区精品视频| 亚洲va国产va欧美va观看| 日韩激情av在线| 久久9热精品视频| 国产一区不卡精品| 粉嫩av亚洲一区二区图片| 成人av在线电影| 色婷婷久久综合| 欧美视频一区二区三区四区| 538在线一区二区精品国产| 日韩视频一区二区三区| 久久综合久久鬼色| 欧美国产1区2区| 亚洲精品免费电影| 亚洲精品视频自拍| 亚洲国产精品久久人人爱| 日本网站在线观看一区二区三区| 久久99国产乱子伦精品免费| 国产99久久久国产精品| 91麻豆免费看片| 欧美高清www午色夜在线视频| 精品久久久久久久人人人人传媒| 久久久久久黄色| 亚洲欧美在线视频观看| 亚洲成av人片在线| 美脚の诱脚舐め脚责91| 国产激情一区二区三区四区 | 一区二区视频在线| 亚洲成人免费av| 久久成人18免费观看| 成人性生交大片免费看中文| 色诱亚洲精品久久久久久| 在线播放中文一区| 国产偷国产偷精品高清尤物| 亚洲免费观看高清完整版在线观看熊 | 成人免费看视频| 欧洲人成人精品| 精品电影一区二区三区 | 亚洲高清久久久| 国产真实乱偷精品视频免| 91在线国产福利| 日韩精品一区二区三区老鸭窝| 国产精品免费视频观看| 亚洲大片精品永久免费| 国产乱人伦精品一区二区在线观看| 99r国产精品| 91精品国产高清一区二区三区蜜臀| 日本一区二区三区四区| 性做久久久久久免费观看欧美| 国产一区二区按摩在线观看| 欧美性受xxxx| 国产网站一区二区三区| 天天综合天天做天天综合| 精品国产凹凸成av人网站| 日韩美女久久久| 久久精品国产亚洲a| 色婷婷久久久综合中文字幕| 欧美成人一区二区三区片免费 | 欧美高清一级片在线| 国产精品久久久久久久久免费相片 | 日本vs亚洲vs韩国一区三区 | 国产白丝精品91爽爽久久| 欧美性猛交xxxx黑人交| 国产精品日日摸夜夜摸av|