⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tzhm.h

📁 基于计算机特征码的软件注册加密及序列号生成的源程序
💻 H
📖 第 1 页 / 共 3 页
字号:
#include <math.h>
#define   DFP_GET_VERSION   0x00074080     
  #define   DFP_SEND_DRIVE_COMMAND   0x0007c084     
  #define   DFP_RECEIVE_DRIVE_DATA   0x0007c088     
  BYTE szSystemInfo[4096]; // 在程序执行完毕后,此处存储取得的系统特征码
    BYTE stemInfonum[4096];
    UINT uSystemInfoLen = 0; // 在程序执行完毕后,此处存储取得的系统特征码的长度  
void len(char* s, char* b);

  #pragma   pack(1)     
  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   _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   _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[512];       //   Buffer   of   arbitrary   length     
                    //   in   which   to   store   the   data   read   from   the   drive.     
  }   SENDCMDOUTPARAMS,   *PSENDCMDOUTPARAMS,   *LPSENDCMDOUTPARAMS;     
    
  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;     


  //********************************

#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 _SRB_IO_CONTROL
{
    ULONG HeaderLength;
    UCHAR Signature[8];
    ULONG Timeout;
    ULONG ControlCode;
    ULONG ReturnCode;
    ULONG Length;
} SRB_IO_CONTROL, *PSRB_IO_CONTROL;











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

//结构定义 
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;

                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 )
                        {
                            // 序列号
                            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;

                            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, 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -