oracle hash password



2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
{*******************************************************}
{                                                       }
{       Oracle Password Hash                            }
{                                                       }
{       版權所有 (C) 2009 Mail:[email protected]  Open[xgc] }
{                                                       }
{*******************************************************}
 
unit OracleHASH;
 
interface
 
uses
  Windows,SysUtils;
 
type
   DES_cblock = array[0..7] of Byte;
   des_ks_struct = packed record
    ks: DES_cblock;
    weak_key: Integer;
  end;
  des_key_schedule = array[1..16] of des_ks_struct;
 
procedure  DES_cbc_encrypt(Source,Dest: pointer; Len: integer; Key, IV: Pointer; Enc:integer); cdecl; external 'libeay32.dll';
procedure DES_set_odd_parity(Key: des_cblock); cdecl; external 'libeay32.dll';
function DES_set_key_checked(key: des_cblock; schedule: des_key_schedule): Integer;cdecl; external 'libeay32.dll';
function Encrypt(name:widestring):string;
 
implementation
 
 
function Encrypt(name:widestring):string;
var
    iv,key: DES_cblock ;
    key_schedule : des_key_schedule;
    num,len,i:word;
    a: array [1..500]of byte;
    b: array [1..500] of byte;
begin
    KEY[0] := $01;
    KEY[1] :=$23;
    KEY[2] :=$45;
    KEY[3] :=$67;
    KEY[4] :=$89;
    KEY[5] :=$AB;
    KEY[6] :=$CD;
    KEY[7] :=$EF;
    len := length(name) *2;
    if len mod 8 <>0 then
    num := len + 8 - len mod 8
    else
    num := len ;
   zeromemory(@a,500);
    move(name[1],a[2],len);
   zeromemory(@b,500);
   ZeroMemory(@iv, SizeOf(iv));
    DES_set_odd_parity(KEY);
    DES_set_key_checked(key,key_schedule);
    DES_cbc_encrypt(@a,@b,len,@key_schedule[1],@iv,1);
    move(b[num-7],key[0],8);
    DES_set_odd_parity(key);
    DES_set_key_checked(key,key_schedule);
    DES_cbc_encrypt(@a,@b,len,@key_schedule[1],@iv,1);
     move(b[num-7],key[0],8);
     for i:=0 to 7 do
       Result := Result + inttohex(key[i],2);
end;
end.
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
{*******************************************************}
{                                                       }
{       Oracle Password Hash                            }
{                                                       }
{       版權所有 (C) 2009 Mail:[email protected]  Open[xgc] }
{                                                       }
{*******************************************************}
 
unit OracleHASH;
 
interface
 
uses
  Windows,SysUtils;
 
type
   DES_cblock = array[0..7] of Byte;
   des_ks_struct = packed record
    ks: DES_cblock;
    weak_key: Integer;
  end;
  des_key_schedule = array[1..16] of des_ks_struct;
 
procedure  DES_cbc_encrypt(Source,Dest: pointer; Len: integer; Key, IV: Pointer; Enc:integer); cdecl; external 'libeay32.dll';
procedure DES_set_odd_parity(Key: des_cblock); cdecl; external 'libeay32.dll';
function DES_set_key_checked(key: des_cblock; schedule: des_key_schedule): Integer;cdecl; external 'libeay32.dll';
function Encrypt(name:widestring):string;
 
implementation
 
 
function Encrypt(name:widestring):string;
var
    iv,key: DES_cblock ;
    key_schedule : des_key_schedule;
    num,len,i:word;
    a: array [1..500]of byte;
    b: array [1..500] of byte;
begin
    KEY[0] := $01;
    KEY[1] :=$23;
    KEY[2] :=$45;
    KEY[3] :=$67;
    KEY[4] :=$89;
    KEY[5] :=$AB;
    KEY[6] :=$CD;
    KEY[7] :=$EF;
    len := length(name) *2;
    if len mod 8 <>0 then
    num := len + 8 - len mod 8
    else
    num := len ;
   zeromemory(@a,500);
    move(name[1],a[2],len);
   zeromemory(@b,500);
   ZeroMemory(@iv, SizeOf(iv));
    DES_set_odd_parity(KEY);
    DES_set_key_checked(key,key_schedule);
    DES_cbc_encrypt(@a,@b,len,@key_schedule[1],@iv,1);
    move(b[num-7],key[0],8);
    DES_set_odd_parity(key);
    DES_set_key_checked(key,key_schedule);
    DES_cbc_encrypt(@a,@b,len,@key_schedule[1],@iv,1);
     move(b[num-7],key[0],8);
     for i:=0 to 7 do
       Result := Result + inttohex(key[i],2);
end;
end.
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章