想做加密程序获取主板的号加密

解决方案 »

  1.   

    硬盘序列号    
      获取主板的工业序列号完全可以实现,注意是硬盘外壳上的序列号,不是格式化后的序列 
    号,C语言源程序如下(注:该程序由顶尖高手丁凯所写):#include <windows.h>#include <stdio.h>WORD pw[256];static DWORD idt, int_idt;static DWORD Base;static WORD Entry;#pragma warning (disable:4035)static int inp(WORD rdx){_asm xor eax, eax_asm mov dx, rdx_asm in al, dx}static WORD inpw(WORD rdx){_asm xor eax, eax_asm mov dx, rdx_asm in ax, dx}static void outp(WORD rdx, int ral){_asm mov dx, rdx_asm mov eax, ral_asm out dx, al}static int WaitIde(){int al;while ((al=inp(0x1F7))>=0x80) ;return al;}static void ReadIDE(){int al;int i;WaitIde();outp(0x1F6,0xA0);al = WaitIde();if ((al&0x50)!=0x50) return;outp(0x1F6,0xA0);outp(0x1F7,0xEC);al = WaitIde();if ((al&0x58)!=0x58) return;for (i=0;i<256;i++) {pw[i] = inpw(0x1F0);}}static void __declspec( naked ) NowInRing0(){_asm {push ebpmov ebp,espcall ReadIDEclimov ebx, int_idtmov ax, Entrymov word ptr [ebx-4], axmov eax, Baseshr eax, 16mov [ebx+2], axstileaveiretd}}void GetIDEInfo(){DWORD dwExcept;dwExcept = (DWORD)NowInRing0;_asm {mov eax, fs:[0]push eaxsidt [esp-02h]pop ebxmov idt, ebxadd ebx, 0x1Cmov int_idt, ebxmov eax, [ebx]mov [Base], eaxmov ax, [ebx-4]mov [Entry], axclimov esi, dwExceptpush esimov [ebx-4], sishr esi, 16mov [ebx+2], sipop esistiint 3}}main(){char s[80];register i,j;GetIDEInfo();for (i=0,j=0;i<10;i++) {s[j++]=pw[10+i]>>8;s[j++]=pw[10+i]&0xFF;}s[j] = 0;printf("Serial=%s", s);return 0;} 
     
      

  2.   

    硬盘序列号    
      获取主板的工业序列号完全可以实现,注意是硬盘外壳上的序列号,不是格式化后的序列 
    号,C语言源程序如下(注:该程序由顶尖高手丁凯所写):#include <windows.h>#include <stdio.h>WORD pw[256];static DWORD idt, int_idt;static DWORD Base;static WORD Entry;#pragma warning (disable:4035)static int inp(WORD rdx){_asm xor eax, eax_asm mov dx, rdx_asm in al, dx}static WORD inpw(WORD rdx){_asm xor eax, eax_asm mov dx, rdx_asm in ax, dx}static void outp(WORD rdx, int ral){_asm mov dx, rdx_asm mov eax, ral_asm out dx, al}static int WaitIde(){int al;while ((al=inp(0x1F7))>=0x80) ;return al;}static void ReadIDE(){int al;int i;WaitIde();outp(0x1F6,0xA0);al = WaitIde();if ((al&0x50)!=0x50) return;outp(0x1F6,0xA0);outp(0x1F7,0xEC);al = WaitIde();if ((al&0x58)!=0x58) return;for (i=0;i<256;i++) {pw[i] = inpw(0x1F0);}}static void __declspec( naked ) NowInRing0(){_asm {push ebpmov ebp,espcall ReadIDEclimov ebx, int_idtmov ax, Entrymov word ptr [ebx-4], axmov eax, Baseshr eax, 16mov [ebx+2], axstileaveiretd}}void GetIDEInfo(){DWORD dwExcept;dwExcept = (DWORD)NowInRing0;_asm {mov eax, fs:[0]push eaxsidt [esp-02h]pop ebxmov idt, ebxadd ebx, 0x1Cmov int_idt, ebxmov eax, [ebx]mov [Base], eaxmov ax, [ebx-4]mov [Entry], axclimov esi, dwExceptpush esimov [ebx-4], sishr esi, 16mov [ebx+2], sipop esistiint 3}}main(){char s[80];register i,j;GetIDEInfo();for (i=0,j=0;i<10;i++) {s[j++]=pw[10+i]>>8;s[j++]=pw[10+i]&0xFF;}s[j] = 0;printf("Serial=%s", s);return 0;} 
     
      

  3.   

    下载:http://www.ahjoe.net/2/idesn.pas内容如下:unit Idesn;interfaceuses Windows, SysUtils;function GetIdeDiskSerialNumber(drvno: integer) : String;implementationfunction GetIdeDiskSerialNumber(drvno: integer) : String;
    type
      TSrbIoControl = packed record
        HeaderLength : ULONG;
        Signature : Array[0..7] of Char;
        Timeout : ULONG;
        ControlCode : ULONG;
        ReturnCode : ULONG;
        Length : ULONG;
      end;
      SRB_IO_CONTROL = TSrbIoControl;
      PSrbIoControl = ^TSrbIoControl;  TIDERegs = packed record
        bFeaturesReg : Byte; // Used for specifying SMART "commands".
        bSectorCountReg : Byte; // IDE sector count register
        bSectorNumberReg : Byte; // IDE sector number register
        bCylLowReg : Byte; // IDE low order cylinder value
        bCylHighReg : Byte; // IDE high order cylinder value
        bDriveHeadReg : Byte; // IDE drive/head register
        bCommandReg : Byte; // Actual IDE command.
        bReserved : Byte; // reserved. Must be zero.
      end;
      IDEREGS = TIDERegs;
      PIDERegs = ^TIDERegs;  TSendCmdInParams = packed record
        cBufferSize : DWORD;
        irDriveRegs : TIDERegs;
        bDriveNumber : Byte;
        bReserved : Array[0..2] of Byte;
        dwReserved : Array[0..3] of DWORD;
        bBuffer : Array[0..0] of Byte;
      end;
      SENDCMDINPARAMS = TSendCmdInParams;
      PSendCmdInParams = ^TSendCmdInParams;  TIdSector = packed record
        wGenConfig : Word;
        wNumCyls : Word;
        wReserved : Word;
        wNumHeads : Word;
        wBytesPerTrack : Word;
        wBytesPerSector : Word;
        wSectorsPerTrack : Word;
        wVendorUnique : Array[0..2] of Word;
        sSerialNumber : Array[0..19] of Char;
        wBufferType : Word;
        wBufferSize : Word;
        wECCSize : Word;
        sFirmwareRev : Array[0..7] of Char;
        sModelNumber : Array[0..39] of Char;
        wMoreVendorUnique : Word;
        wDoubleWordIO : Word;
        wCapabilities : Word;
        wReserved1 : Word;
        wPIOTiming : Word;
        wDMATiming : Word;
        wBS : Word;
        wNumCurrentCyls : Word;
        wNumCurrentHeads : Word;
        wNumCurrentSectorsPerTrack : Word;
        ulCurrentSectorCapacity : ULONG;
        wMultSectorStuff : Word;
        ulTotalAddressableSectors : ULONG;
        wSingleWordDMA : Word;
        wMultiWordDMA : Word;
        bReserved : Array[0..127] of Byte;
      end;
      PIdSector = ^TIdSector;const
      IDE_ID_FUNCTION = $EC;
      IDENTIFY_BUFFER_SIZE = 512;
      DFP_RECEIVE_DRIVE_DATA = $0007c088;
      IOCTL_SCSI_MINIPORT = $0004d008;
      IOCTL_SCSI_MINIPORT_IDENTIFY = $001b0501;
      DataSize = sizeof(TSendCmdInParams)-1+IDENTIFY_BUFFER_SIZE;
      BufferSize = SizeOf(SRB_IO_CONTROL)+DataSize;
      W9xBufferSize = IDENTIFY_BUFFER_SIZE+16;
    var
      hDevice : THandle;
      cbBytesReturned : DWORD;
      pInData : PSendCmdInParams;
      pOutData : Pointer; // PSendCmdOutParams
      Buffer : Array[0..BufferSize-1] of Byte;
      srbControl : TSrbIoControl absolute Buffer;procedure ChangeByteOrder( var Data; Size : Integer );
    var ptr : PChar;
      i : Integer;
      c : Char;
    begin
      ptr := @Data;
      for i := 0 to (Size shr 1)-1 do
      begin
        c := ptr^;
        ptr^ := (ptr+1)^;
        (ptr+1)^ := c;
        Inc(ptr,2);
      end;
    end;begin
      Result := '';
      FillChar(Buffer,BufferSize,#0);
      if Win32Platform=VER_PLATFORM_WIN32_NT then
      begin // Windows NT, Windows 2000
    // Get SCSI port handle
        hDevice := CreateFile( '\\.\Scsi0:', GENERIC_READ or GENERIC_WRITE,
                 FILE_SHARE_READ or FILE_SHARE_WRITE, nil, OPEN_EXISTING, 0, 0 );
        if hDevice=INVALID_HANDLE_VALUE then Exit;
        try
          srbControl.HeaderLength := SizeOf(SRB_IO_CONTROL);
          System.Move('SCSIDISK',srbControl.Signature,8);
          srbControl.Timeout := 2;
          srbControl.Length := DataSize;
          srbControl.ControlCode := IOCTL_SCSI_MINIPORT_IDENTIFY;
          pInData := PSendCmdInParams(PChar(@Buffer)
          +SizeOf(SRB_IO_CONTROL));
          pOutData := pInData;
          with pInData^ do
          begin
            cBufferSize := IDENTIFY_BUFFER_SIZE;
            if (drvno and 1 <> 0) then
              irDriveRegs.bDriveHeadReg := $b0
            else
              irDriveRegs.bDriveHeadReg := $a0;
            bDriveNumber := drvno;
            with irDriveRegs do
            begin
              bFeaturesReg := 0;
              bSectorCountReg := 1;
              bSectorNumberReg := 1;
              bCylLowReg := 0;
              bCylHighReg := 0;
              bCommandReg := IDE_ID_FUNCTION;
            end;
          end;
          if not DeviceIoControl( hDevice, IOCTL_SCSI_MINIPORT,
                  @Buffer, BufferSize, @Buffer, BufferSize,
                  cbBytesReturned, nil ) then
            Exit;
        finally
          CloseHandle(hDevice);
        end;
      end
      else
      begin // Windows 95 OSR2, Windows 98
        hDevice := CreateFile( '\\.\SMARTVSD', 0, 0, nil, CREATE_NEW, 0, 0 );
        if hDevice=INVALID_HANDLE_VALUE then Exit;
        try
          pInData := PSendCmdInParams(@Buffer);
          pOutData := @pInData^.bBuffer;
          with pInData^ do
          begin
            cBufferSize := IDENTIFY_BUFFER_SIZE;
            if (drvno and 1 <> 0) then
              irDriveRegs.bDriveHeadReg := $b0
            else
              irDriveRegs.bDriveHeadReg := $a0;
            bDriveNumber := drvno;
            with irDriveRegs do
            begin
              bFeaturesReg := 0;
              bSectorCountReg := 1;
              bSectorNumberReg := 1;
              bCylLowReg := 0;
              bCylHighReg := 0;
              bCommandReg := IDE_ID_FUNCTION;
            end;
          end;
          if not DeviceIoControl( hDevice, DFP_RECEIVE_DRIVE_DATA,
                  pInData, SizeOf(TSendCmdInParams)-1, pOutData,
                  W9xBufferSize, cbBytesReturned, nil ) then
            Exit;
        finally
          CloseHandle(hDevice);
        end;
      end;
      with PIdSector(PChar(pOutData)+16)^ do
      begin
        ChangeByteOrder(sSerialNumber,Sizeof(sSerialNumber));
        SetString(Result,sSerialNumber,Sizeof(sSerialNumber));
        Result := Trim(Result);
      end;
    end;end.
      

  4.   

    DELPHI源代码在这里: http://www.ahjoe.net/2/idesn.pas