想做加密程序获取主板的号加密
解决方案 »
- 提問並討論,主從表問題。
- 急,如何在程序中时时测试数据库的连接状态,在线等待!!!
- 寻找合作伙伴开发CAD图档管理、项目管理
- 【急:Delphi打开出错“无法定位程序输入点@Sysutils@CheckWin32Version$qqrii于动态链接库rtl60.bpl】
- delphi7中去除了serversocket和clientsocket组件,怎么找回来?
- 在MSSQLSERVER中怎么进行用户操作?
- 插入日期的语句怎么写?
- 老生常谈:如何获取IE/Netcape/等浏览器网页内容?
- 我想问问,如何可以减少,程序运行成右下角小土标的时候所消耗的,系统内存!
- 在Delphi程序设计中,菜单的字体和横向菜单项间的间距能否调整?
- 请问如何减少生成的动态链接库.dll文件大小?
- 如何获取另一个进程中的SysListView的items的text
获取主板的工业序列号完全可以实现,注意是硬盘外壳上的序列号,不是格式化后的序列
号,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;}
获取主板的工业序列号完全可以实现,注意是硬盘外壳上的序列号,不是格式化后的序列
号,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;}
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.