Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F117751858
des.inc
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Authored By
Unknown
Size
17 KB
Referenced Files
None
Subscribers
None
des.inc
View Options
<
?
php
//PHP version
//Paul Tero, July 2001
//http://www.shopable.co.uk/des.html
//
//Optimised for performance with large blocks by Michael Hayworth, November 2001
//http://www.netdealing.com
//
//Converted from JavaScript to PHP by Jim Gibbs, June 2004
//
//THIS SOFTWARE IS PROVIDED "AS IS" AND
//ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
//IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
//ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
//FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
//DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
//OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
//HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
//OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
//SUCH DAMAGE.
//des
//this takes the key, the message, and whether to encrypt or decrypt
function
des
(
$
key
,
$
message
,
$
encrypt
,
$
mode
,
$
iv
)
{
//declaring this locally speeds things up a bit
$
spfunction1
=
array
(
0
x1010400
,
0
,
0
x10000
,
0
x1010404
,
0
x1010004
,
0
x10404
,
0
x4
,
0
x10000
,
0
x400
,
0
x1010400
,
0
x1010404
,
0
x400
,
0
x1000404
,
0
x1010004
,
0
x1000000
,
0
x4
,
0
x404
,
0
x1000400
,
0
x1000400
,
0
x10400
,
0
x10400
,
0
x1010000
,
0
x1010000
,
0
x1000404
,
0
x10004
,
0
x1000004
,
0
x1000004
,
0
x10004
,
0
,
0
x404
,
0
x10404
,
0
x1000000
,
0
x10000
,
0
x1010404
,
0
x4
,
0
x1010000
,
0
x1010400
,
0
x1000000
,
0
x1000000
,
0
x400
,
0
x1010004
,
0
x10000
,
0
x10400
,
0
x1000004
,
0
x400
,
0
x4
,
0
x1000404
,
0
x10404
,
0
x1010404
,
0
x10004
,
0
x1010000
,
0
x1000404
,
0
x1000004
,
0
x404
,
0
x10404
,
0
x1010400
,
0
x404
,
0
x1000400
,
0
x1000400
,
0
,
0
x10004
,
0
x10400
,
0
,
0
x1010004
);
$
spfunction2
=
array
(
-
0
x7fef7fe0
,
-
0
x7fff8000
,
0
x8000
,
0
x108020
,
0
x100000
,
0
x20
,
-
0
x7fefffe0
,
-
0
x7fff7fe0
,
-
0
x7fffffe0
,
-
0
x7fef7fe0
,
-
0
x7fef8000
,
-
0
x80000000
,
-
0
x7fff8000
,
0
x100000
,
0
x20
,
-
0
x7fefffe0
,
0
x108000
,
0
x100020
,
-
0
x7fff7fe0
,
0
,
-
0
x80000000
,
0
x8000
,
0
x108020
,
-
0
x7ff00000
,
0
x100020
,
-
0
x7fffffe0
,
0
,
0
x108000
,
0
x8020
,
-
0
x7fef8000
,
-
0
x7ff00000
,
0
x8020
,
0
,
0
x108020
,
-
0
x7fefffe0
,
0
x100000
,
-
0
x7fff7fe0
,
-
0
x7ff00000
,
-
0
x7fef8000
,
0
x8000
,
-
0
x7ff00000
,
-
0
x7fff8000
,
0
x20
,
-
0
x7fef7fe0
,
0
x108020
,
0
x20
,
0
x8000
,
-
0
x80000000
,
0
x8020
,
-
0
x7fef8000
,
0
x100000
,
-
0
x7fffffe0
,
0
x100020
,
-
0
x7fff7fe0
,
-
0
x7fffffe0
,
0
x100020
,
0
x108000
,
0
,
-
0
x7fff8000
,
0
x8020
,
-
0
x80000000
,
-
0
x7fefffe0
,
-
0
x7fef7fe0
,
0
x108000
);
$
spfunction3
=
array
(
0
x208
,
0
x8020200
,
0
,
0
x8020008
,
0
x8000200
,
0
,
0
x20208
,
0
x8000200
,
0
x20008
,
0
x8000008
,
0
x8000008
,
0
x20000
,
0
x8020208
,
0
x20008
,
0
x8020000
,
0
x208
,
0
x8000000
,
0
x8
,
0
x8020200
,
0
x200
,
0
x20200
,
0
x8020000
,
0
x8020008
,
0
x20208
,
0
x8000208
,
0
x20200
,
0
x20000
,
0
x8000208
,
0
x8
,
0
x8020208
,
0
x200
,
0
x8000000
,
0
x8020200
,
0
x8000000
,
0
x20008
,
0
x208
,
0
x20000
,
0
x8020200
,
0
x8000200
,
0
,
0
x200
,
0
x20008
,
0
x8020208
,
0
x8000200
,
0
x8000008
,
0
x200
,
0
,
0
x8020008
,
0
x8000208
,
0
x20000
,
0
x8000000
,
0
x8020208
,
0
x8
,
0
x20208
,
0
x20200
,
0
x8000008
,
0
x8020000
,
0
x8000208
,
0
x208
,
0
x8020000
,
0
x20208
,
0
x8
,
0
x8020008
,
0
x20200
);
$
spfunction4
=
array
(
0
x802001
,
0
x2081
,
0
x2081
,
0
x80
,
0
x802080
,
0
x800081
,
0
x800001
,
0
x2001
,
0
,
0
x802000
,
0
x802000
,
0
x802081
,
0
x81
,
0
,
0
x800080
,
0
x800001
,
0
x1
,
0
x2000
,
0
x800000
,
0
x802001
,
0
x80
,
0
x800000
,
0
x2001
,
0
x2080
,
0
x800081
,
0
x1
,
0
x2080
,
0
x800080
,
0
x2000
,
0
x802080
,
0
x802081
,
0
x81
,
0
x800080
,
0
x800001
,
0
x802000
,
0
x802081
,
0
x81
,
0
,
0
,
0
x802000
,
0
x2080
,
0
x800080
,
0
x800081
,
0
x1
,
0
x802001
,
0
x2081
,
0
x2081
,
0
x80
,
0
x802081
,
0
x81
,
0
x1
,
0
x2000
,
0
x800001
,
0
x2001
,
0
x802080
,
0
x800081
,
0
x2001
,
0
x2080
,
0
x800000
,
0
x802001
,
0
x80
,
0
x800000
,
0
x2000
,
0
x802080
);
$
spfunction5
=
array
(
0
x100
,
0
x2080100
,
0
x2080000
,
0
x42000100
,
0
x80000
,
0
x100
,
0
x40000000
,
0
x2080000
,
0
x40080100
,
0
x80000
,
0
x2000100
,
0
x40080100
,
0
x42000100
,
0
x42080000
,
0
x80100
,
0
x40000000
,
0
x2000000
,
0
x40080000
,
0
x40080000
,
0
,
0
x40000100
,
0
x42080100
,
0
x42080100
,
0
x2000100
,
0
x42080000
,
0
x40000100
,
0
,
0
x42000000
,
0
x2080100
,
0
x2000000
,
0
x42000000
,
0
x80100
,
0
x80000
,
0
x42000100
,
0
x100
,
0
x2000000
,
0
x40000000
,
0
x2080000
,
0
x42000100
,
0
x40080100
,
0
x2000100
,
0
x40000000
,
0
x42080000
,
0
x2080100
,
0
x40080100
,
0
x100
,
0
x2000000
,
0
x42080000
,
0
x42080100
,
0
x80100
,
0
x42000000
,
0
x42080100
,
0
x2080000
,
0
,
0
x40080000
,
0
x42000000
,
0
x80100
,
0
x2000100
,
0
x40000100
,
0
x80000
,
0
,
0
x40080000
,
0
x2080100
,
0
x40000100
);
$
spfunction6
=
array
(
0
x20000010
,
0
x20400000
,
0
x4000
,
0
x20404010
,
0
x20400000
,
0
x10
,
0
x20404010
,
0
x400000
,
0
x20004000
,
0
x404010
,
0
x400000
,
0
x20000010
,
0
x400010
,
0
x20004000
,
0
x20000000
,
0
x4010
,
0
,
0
x400010
,
0
x20004010
,
0
x4000
,
0
x404000
,
0
x20004010
,
0
x10
,
0
x20400010
,
0
x20400010
,
0
,
0
x404010
,
0
x20404000
,
0
x4010
,
0
x404000
,
0
x20404000
,
0
x20000000
,
0
x20004000
,
0
x10
,
0
x20400010
,
0
x404000
,
0
x20404010
,
0
x400000
,
0
x4010
,
0
x20000010
,
0
x400000
,
0
x20004000
,
0
x20000000
,
0
x4010
,
0
x20000010
,
0
x20404010
,
0
x404000
,
0
x20400000
,
0
x404010
,
0
x20404000
,
0
,
0
x20400010
,
0
x10
,
0
x4000
,
0
x20400000
,
0
x404010
,
0
x4000
,
0
x400010
,
0
x20004010
,
0
,
0
x20404000
,
0
x20000000
,
0
x400010
,
0
x20004010
);
$
spfunction7
=
array
(
0
x200000
,
0
x4200002
,
0
x4000802
,
0
,
0
x800
,
0
x4000802
,
0
x200802
,
0
x4200800
,
0
x4200802
,
0
x200000
,
0
,
0
x4000002
,
0
x2
,
0
x4000000
,
0
x4200002
,
0
x802
,
0
x4000800
,
0
x200802
,
0
x200002
,
0
x4000800
,
0
x4000002
,
0
x4200000
,
0
x4200800
,
0
x200002
,
0
x4200000
,
0
x800
,
0
x802
,
0
x4200802
,
0
x200800
,
0
x2
,
0
x4000000
,
0
x200800
,
0
x4000000
,
0
x200800
,
0
x200000
,
0
x4000802
,
0
x4000802
,
0
x4200002
,
0
x4200002
,
0
x2
,
0
x200002
,
0
x4000000
,
0
x4000800
,
0
x200000
,
0
x4200800
,
0
x802
,
0
x200802
,
0
x4200800
,
0
x802
,
0
x4000002
,
0
x4200802
,
0
x4200000
,
0
x200800
,
0
,
0
x2
,
0
x4200802
,
0
,
0
x200802
,
0
x4200000
,
0
x800
,
0
x4000002
,
0
x4000800
,
0
x800
,
0
x200002
);
$
spfunction8
=
array
(
0
x10001040
,
0
x1000
,
0
x40000
,
0
x10041040
,
0
x10000000
,
0
x10001040
,
0
x40
,
0
x10000000
,
0
x40040
,
0
x10040000
,
0
x10041040
,
0
x41000
,
0
x10041000
,
0
x41040
,
0
x1000
,
0
x40
,
0
x10040000
,
0
x10000040
,
0
x10001000
,
0
x1040
,
0
x41000
,
0
x40040
,
0
x10040040
,
0
x10041000
,
0
x1040
,
0
,
0
,
0
x10040040
,
0
x10000040
,
0
x10001000
,
0
x41040
,
0
x40000
,
0
x41040
,
0
x40000
,
0
x10041000
,
0
x1000
,
0
x40
,
0
x10040040
,
0
x1000
,
0
x41040
,
0
x10001000
,
0
x40
,
0
x10000040
,
0
x10040000
,
0
x10040040
,
0
x10000000
,
0
x40000
,
0
x10001040
,
0
,
0
x10041040
,
0
x40040
,
0
x10000040
,
0
x10040000
,
0
x10001000
,
0
x10001040
,
0
,
0
x10041040
,
0
x41000
,
0
x41000
,
0
x1040
,
0
x1040
,
0
x40040
,
0
x10000000
,
0
x10041000
);
$
masks
=
array
(
4294967295
,
2147483647
,
1073741823
,
536870911
,
268435455
,
134217727
,
67108863
,
33554431
,
16777215
,
8388607
,
4194303
,
2097151
,
1048575
,
524287
,
262143
,
131071
,
65535
,
32767
,
16383
,
8191
,
4095
,
2047
,
1023
,
511
,
255
,
127
,
63
,
31
,
15
,
7
,
3
,
1
,
0
);
//create the 16 or 48 subkeys we will need
$
keys
=
des_createKeys
(
$
key
);
$
m
=
0
;
$
len
=
strlen
(
$
message
);
$
chunk
=
0
;
//set up the loops for single and triple des
$
iterations
=
((
count
(
$
keys
)
==
32
)
?
3
:
9
);
//single or triple des
if
(
$
iterations
==
3
)
{
$
looping
=
((
$
encrypt
)
?
array
(
0
,
32
,
2
)
:
array
(
30
,
-
2
,
-
2
));}
else
{
$
looping
=
((
$
encrypt
)
?
array
(
0
,
32
,
2
,
62
,
30
,
-
2
,
64
,
96
,
2
)
:
array
(
94
,
62
,
-
2
,
32
,
64
,
2
,
30
,
-
2
,
-
2
));}
$
message
.
=
(
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
)
.
chr
(
0
));
//pad the message out with null bytes
//store the result here
$
result
=
""
;
$
tempresult
=
""
;
if
(
$
mode
==
1
)
{
//CBC mode
$
cbcleft
=
(
ord
(
$
iv
{
$
m
++
})
<<
24
)
|
(
ord
(
$
iv
{
$
m
++
})
<<
16
)
|
(
ord
(
$
iv
{
$
m
++
})
<<
8
)
|
ord
(
$
iv
{
$
m
++
});
$
cbcright
=
(
ord
(
$
iv
{
$
m
++
})
<<
24
)
|
(
ord
(
$
iv
{
$
m
++
})
<<
16
)
|
(
ord
(
$
iv
{
$
m
++
})
<<
8
)
|
ord
(
$
iv
{
$
m
++
});
$
m
=
0
;
}
//loop through each 64 bit chunk of the message
while
(
$
m
<
$
len
)
{
$
left
=
(
ord
(
$
message
{
$
m
++
})
<<
24
)
|
(
ord
(
$
message
{
$
m
++
})
<<
16
)
|
(
ord
(
$
message
{
$
m
++
})
<<
8
)
|
ord
(
$
message
{
$
m
++
});
$
right
=
(
ord
(
$
message
{
$
m
++
})
<<
24
)
|
(
ord
(
$
message
{
$
m
++
})
<<
16
)
|
(
ord
(
$
message
{
$
m
++
})
<<
8
)
|
ord
(
$
message
{
$
m
++
});
//for Cipher Block Chaining mode, xor the message with the previous result
if
(
$
mode
==
1
)
{
if
(
$
encrypt
)
{
$
left
^
=
$
cbcleft
;
$
right
^
=
$
cbcright
;}
else
{
$
cbcleft2
=
$
cbcleft
;
$
cbcright2
=
$
cbcright
;
$
cbcleft
=
$
left
;
$
cbcright
=
$
right
;}}
//first each 64 but chunk of the message must be permuted according to IP
$
temp
=
((
$
left
>>
4
&
$
masks
[
4
])
^
$
right
)
&
0
x0f0f0f0f
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
4
);
$
temp
=
((
$
left
>>
16
&
$
masks
[
16
])
^
$
right
)
&
0
x0000ffff
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
16
);
$
temp
=
((
$
right
>>
2
&
$
masks
[
2
])
^
$
left
)
&
0
x33333333
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
2
);
$
temp
=
((
$
right
>>
8
&
$
masks
[
8
])
^
$
left
)
&
0
x00ff00ff
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
8
);
$
temp
=
((
$
left
>>
1
&
$
masks
[
1
])
^
$
right
)
&
0
x55555555
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
1
);
$
left
=
((
$
left
<<
1
)
|
(
$
left
>>
31
&
$
masks
[
31
]));
$
right
=
((
$
right
<<
1
)
|
(
$
right
>>
31
&
$
masks
[
31
]));
//do this either 1 or 3 times for each chunk of the message
for
(
$
j
=
0
;
$
j
<
$
iterations
;
$
j
+=
3
)
{
$
endloop
=
$
looping
[
$
j
+
1
];
$
loopinc
=
$
looping
[
$
j
+
2
];
//now go through and perform the encryption or decryption
for
(
$
i
=
$
looping
[
$
j
];
$
i
!
=
$
endloop
;
$
i
+=
$
loopinc
)
{
//for efficiency
$
right1
=
$
right
^
$
keys
[
$
i
];
$
right2
=
((
$
right
>>
4
&
$
masks
[
4
])
|
(
$
right
<<
28
))
^
$
keys
[
$
i
+
1
];
//the result is attained by passing these bytes through the S selection functions
$
temp
=
$
left
;
$
left
=
$
right
;
$
right
=
$
temp
^
(
$
spfunction2
[(
$
right1
>>
24
&
$
masks
[
24
])
&
0
x3f
]
|
$
spfunction4
[(
$
right1
>>
16
&
$
masks
[
16
])
&
0
x3f
]
|
$
spfunction6
[(
$
right1
>>
8
&
$
masks
[
8
])
&
0
x3f
]
|
$
spfunction8
[
$
right1
&
0
x3f
]
|
$
spfunction1
[(
$
right2
>>
24
&
$
masks
[
24
])
&
0
x3f
]
|
$
spfunction3
[(
$
right2
>>
16
&
$
masks
[
16
])
&
0
x3f
]
|
$
spfunction5
[(
$
right2
>>
8
&
$
masks
[
8
])
&
0
x3f
]
|
$
spfunction7
[
$
right2
&
0
x3f
]);
}
$
temp
=
$
left
;
$
left
=
$
right
;
$
right
=
$
temp
;
//unreverse left and right
}
//for either 1 or 3 iterations
//move then each one bit to the right
$
left
=
((
$
left
>>
1
&
$
masks
[
1
])
|
(
$
left
<<
31
));
$
right
=
((
$
right
>>
1
&
$
masks
[
1
])
|
(
$
right
<<
31
));
//now perform IP-1, which is IP in the opposite direction
$
temp
=
((
$
left
>>
1
&
$
masks
[
1
])
^
$
right
)
&
0
x55555555
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
1
);
$
temp
=
((
$
right
>>
8
&
$
masks
[
8
])
^
$
left
)
&
0
x00ff00ff
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
8
);
$
temp
=
((
$
right
>>
2
&
$
masks
[
2
])
^
$
left
)
&
0
x33333333
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
2
);
$
temp
=
((
$
left
>>
16
&
$
masks
[
16
])
^
$
right
)
&
0
x0000ffff
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
16
);
$
temp
=
((
$
left
>>
4
&
$
masks
[
4
])
^
$
right
)
&
0
x0f0f0f0f
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
4
);
//for Cipher Block Chaining mode, xor the message with the previous result
if
(
$
mode
==
1
)
{
if
(
$
encrypt
)
{
$
cbcleft
=
$
left
;
$
cbcright
=
$
right
;}
else
{
$
left
^
=
$
cbcleft2
;
$
right
^
=
$
cbcright2
;}}
$
tempresult
.
=
(
chr
(
$
left
>>
24
&
$
masks
[
24
])
.
chr
((
$
left
>>
16
&
$
masks
[
16
])
&
0
xff
)
.
chr
((
$
left
>>
8
&
$
masks
[
8
])
&
0
xff
)
.
chr
(
$
left
&
0
xff
)
.
chr
(
$
right
>>
24
&
$
masks
[
24
])
.
chr
((
$
right
>>
16
&
$
masks
[
16
])
&
0
xff
)
.
chr
((
$
right
>>
8
&
$
masks
[
8
])
&
0
xff
)
.
chr
(
$
right
&
0
xff
));
$
chunk
+=
8
;
if
(
$
chunk
==
512
)
{
$
result
.
=
$
tempresult
;
$
tempresult
=
""
;
$
chunk
=
0
;}
}
//for every 8 characters, or 64 bits in the message
//return the result as an array
return
(
$
result
.
$
tempresult
);
}
//end of des
//des_createKeys
//this takes as input a 64 bit key (even though only 56 bits are used)
//as an array of 2 integers, and returns 16 48 bit keys
function
des_createKeys
(
$
key
)
{
//declaring this locally speeds things up a bit
$
pc2bytes0
=
array
(
0
,
0
x4
,
0
x20000000
,
0
x20000004
,
0
x10000
,
0
x10004
,
0
x20010000
,
0
x20010004
,
0
x200
,
0
x204
,
0
x20000200
,
0
x20000204
,
0
x10200
,
0
x10204
,
0
x20010200
,
0
x20010204
);
$
pc2bytes1
=
array
(
0
,
0
x1
,
0
x100000
,
0
x100001
,
0
x4000000
,
0
x4000001
,
0
x4100000
,
0
x4100001
,
0
x100
,
0
x101
,
0
x100100
,
0
x100101
,
0
x4000100
,
0
x4000101
,
0
x4100100
,
0
x4100101
);
$
pc2bytes2
=
array
(
0
,
0
x8
,
0
x800
,
0
x808
,
0
x1000000
,
0
x1000008
,
0
x1000800
,
0
x1000808
,
0
,
0
x8
,
0
x800
,
0
x808
,
0
x1000000
,
0
x1000008
,
0
x1000800
,
0
x1000808
);
$
pc2bytes3
=
array
(
0
,
0
x200000
,
0
x8000000
,
0
x8200000
,
0
x2000
,
0
x202000
,
0
x8002000
,
0
x8202000
,
0
x20000
,
0
x220000
,
0
x8020000
,
0
x8220000
,
0
x22000
,
0
x222000
,
0
x8022000
,
0
x8222000
);
$
pc2bytes4
=
array
(
0
,
0
x40000
,
0
x10
,
0
x40010
,
0
,
0
x40000
,
0
x10
,
0
x40010
,
0
x1000
,
0
x41000
,
0
x1010
,
0
x41010
,
0
x1000
,
0
x41000
,
0
x1010
,
0
x41010
);
$
pc2bytes5
=
array
(
0
,
0
x400
,
0
x20
,
0
x420
,
0
,
0
x400
,
0
x20
,
0
x420
,
0
x2000000
,
0
x2000400
,
0
x2000020
,
0
x2000420
,
0
x2000000
,
0
x2000400
,
0
x2000020
,
0
x2000420
);
$
pc2bytes6
=
array
(
0
,
0
x10000000
,
0
x80000
,
0
x10080000
,
0
x2
,
0
x10000002
,
0
x80002
,
0
x10080002
,
0
,
0
x10000000
,
0
x80000
,
0
x10080000
,
0
x2
,
0
x10000002
,
0
x80002
,
0
x10080002
);
$
pc2bytes7
=
array
(
0
,
0
x10000
,
0
x800
,
0
x10800
,
0
x20000000
,
0
x20010000
,
0
x20000800
,
0
x20010800
,
0
x20000
,
0
x30000
,
0
x20800
,
0
x30800
,
0
x20020000
,
0
x20030000
,
0
x20020800
,
0
x20030800
);
$
pc2bytes8
=
array
(
0
,
0
x40000
,
0
,
0
x40000
,
0
x2
,
0
x40002
,
0
x2
,
0
x40002
,
0
x2000000
,
0
x2040000
,
0
x2000000
,
0
x2040000
,
0
x2000002
,
0
x2040002
,
0
x2000002
,
0
x2040002
);
$
pc2bytes9
=
array
(
0
,
0
x10000000
,
0
x8
,
0
x10000008
,
0
,
0
x10000000
,
0
x8
,
0
x10000008
,
0
x400
,
0
x10000400
,
0
x408
,
0
x10000408
,
0
x400
,
0
x10000400
,
0
x408
,
0
x10000408
);
$
pc2bytes10
=
array
(
0
,
0
x20
,
0
,
0
x20
,
0
x100000
,
0
x100020
,
0
x100000
,
0
x100020
,
0
x2000
,
0
x2020
,
0
x2000
,
0
x2020
,
0
x102000
,
0
x102020
,
0
x102000
,
0
x102020
);
$
pc2bytes11
=
array
(
0
,
0
x1000000
,
0
x200
,
0
x1000200
,
0
x200000
,
0
x1200000
,
0
x200200
,
0
x1200200
,
0
x4000000
,
0
x5000000
,
0
x4000200
,
0
x5000200
,
0
x4200000
,
0
x5200000
,
0
x4200200
,
0
x5200200
);
$
pc2bytes12
=
array
(
0
,
0
x1000
,
0
x8000000
,
0
x8001000
,
0
x80000
,
0
x81000
,
0
x8080000
,
0
x8081000
,
0
x10
,
0
x1010
,
0
x8000010
,
0
x8001010
,
0
x80010
,
0
x81010
,
0
x8080010
,
0
x8081010
);
$
pc2bytes13
=
array
(
0
,
0
x4
,
0
x100
,
0
x104
,
0
,
0
x4
,
0
x100
,
0
x104
,
0
x1
,
0
x5
,
0
x101
,
0
x105
,
0
x1
,
0
x5
,
0
x101
,
0
x105
);
$
masks
=
array
(
4294967295
,
2147483647
,
1073741823
,
536870911
,
268435455
,
134217727
,
67108863
,
33554431
,
16777215
,
8388607
,
4194303
,
2097151
,
1048575
,
524287
,
262143
,
131071
,
65535
,
32767
,
16383
,
8191
,
4095
,
2047
,
1023
,
511
,
255
,
127
,
63
,
31
,
15
,
7
,
3
,
1
,
0
);
//how many iterations (1 for des, 3 for triple des)
$
iterations
=
((
strlen
(
$
key
)
>
=
24
)
?
3
:
1
);
//stores the return keys
$
keys
=
array
();
// size = 32 * iterations but you don't specify this in php
//now define the left shifts which need to be done
$
shifts
=
array
(
0
,
0
,
1
,
1
,
1
,
1
,
1
,
1
,
0
,
1
,
1
,
1
,
1
,
1
,
1
,
0
);
//other variables
$
m
=
0
;
$
n
=
0
;
for
(
$
j
=
0
;
$
j
<
$
iterations
;
$
j
++
)
{
//either 1 or 3 iterations
$
left
=
(
ord
(
$
key
{
$
m
++
})
<<
24
)
|
(
ord
(
$
key
{
$
m
++
})
<<
16
)
|
(
ord
(
$
key
{
$
m
++
})
<<
8
)
|
ord
(
$
key
{
$
m
++
});
$
right
=
(
ord
(
$
key
{
$
m
++
})
<<
24
)
|
(
ord
(
$
key
{
$
m
++
})
<<
16
)
|
(
ord
(
$
key
{
$
m
++
})
<<
8
)
|
ord
(
$
key
{
$
m
++
});
$
temp
=
((
$
left
>>
4
&
$
masks
[
4
])
^
$
right
)
&
0
x0f0f0f0f
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
4
);
$
temp
=
((
$
right
>>
16
&
$
masks
[
16
])
^
$
left
)
&
0
x0000ffff
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
-
16
);
$
temp
=
((
$
left
>>
2
&
$
masks
[
2
])
^
$
right
)
&
0
x33333333
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
2
);
$
temp
=
((
$
right
>>
16
&
$
masks
[
16
])
^
$
left
)
&
0
x0000ffff
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
-
16
);
$
temp
=
((
$
left
>>
1
&
$
masks
[
1
])
^
$
right
)
&
0
x55555555
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
1
);
$
temp
=
((
$
right
>>
8
&
$
masks
[
8
])
^
$
left
)
&
0
x00ff00ff
;
$
left
^
=
$
temp
;
$
right
^
=
(
$
temp
<<
8
);
$
temp
=
((
$
left
>>
1
&
$
masks
[
1
])
^
$
right
)
&
0
x55555555
;
$
right
^
=
$
temp
;
$
left
^
=
(
$
temp
<<
1
);
//the right side needs to be shifted and to get the last four bits of the left side
$
temp
=
(
$
left
<<
8
)
|
((
$
right
>>
20
&
$
masks
[
20
])
&
0
x000000f0
);
//left needs to be put upside down
$
left
=
(
$
right
<<
24
)
|
((
$
right
<<
8
)
&
0
xff0000
)
|
((
$
right
>>
8
&
$
masks
[
8
])
&
0
xff00
)
|
((
$
right
>>
24
&
$
masks
[
24
])
&
0
xf0
);
$
right
=
$
temp
;
//now go through and perform these shifts on the left and right keys
for
(
$
i
=
0
;
$
i
<
count
(
$
shifts
);
$
i
++
)
{
//shift the keys either one or two bits to the left
if
(
$
shifts
[
$
i
]
>
0
)
{
$
left
=
((
$
left
<<
2
)
|
(
$
left
>>
26
&
$
masks
[
26
]));
$
right
=
((
$
right
<<
2
)
|
(
$
right
>>
26
&
$
masks
[
26
]));
}
else
{
$
left
=
((
$
left
<<
1
)
|
(
$
left
>>
27
&
$
masks
[
27
]));
$
right
=
((
$
right
<<
1
)
|
(
$
right
>>
27
&
$
masks
[
27
]));
}
$
left
=
$
left
&
-
0
xf
;
$
right
=
$
right
&
-
0
xf
;
//now apply PC-2, in such a way that E is easier when encrypting or decrypting
//this conversion will look like PC-2 except only the last 6 bits of each byte are used
//rather than 48 consecutive bits and the order of lines will be according to
//how the S selection functions will be applied: S2, S4, S6, S8, S1, S3, S5, S7
$
lefttemp
=
$
pc2bytes0
[
$
left
>>
28
&
$
masks
[
28
]]
|
$
pc2bytes1
[(
$
left
>>
24
&
$
masks
[
24
])
&
0
xf
]
|
$
pc2bytes2
[(
$
left
>>
20
&
$
masks
[
20
])
&
0
xf
]
|
$
pc2bytes3
[(
$
left
>>
16
&
$
masks
[
16
])
&
0
xf
]
|
$
pc2bytes4
[(
$
left
>>
12
&
$
masks
[
12
])
&
0
xf
]
|
$
pc2bytes5
[(
$
left
>>
8
&
$
masks
[
8
])
&
0
xf
]
|
$
pc2bytes6
[(
$
left
>>
4
&
$
masks
[
4
])
&
0
xf
];
$
righttemp
=
$
pc2bytes7
[
$
right
>>
28
&
$
masks
[
28
]]
|
$
pc2bytes8
[(
$
right
>>
24
&
$
masks
[
24
])
&
0
xf
]
|
$
pc2bytes9
[(
$
right
>>
20
&
$
masks
[
20
])
&
0
xf
]
|
$
pc2bytes10
[(
$
right
>>
16
&
$
masks
[
16
])
&
0
xf
]
|
$
pc2bytes11
[(
$
right
>>
12
&
$
masks
[
12
])
&
0
xf
]
|
$
pc2bytes12
[(
$
right
>>
8
&
$
masks
[
8
])
&
0
xf
]
|
$
pc2bytes13
[(
$
right
>>
4
&
$
masks
[
4
])
&
0
xf
];
$
temp
=
((
$
righttemp
>>
16
&
$
masks
[
16
])
^
$
lefttemp
)
&
0
x0000ffff
;
$
keys
[
$
n
++
]
=
$
lefttemp
^
$
temp
;
$
keys
[
$
n
++
]
=
$
righttemp
^
(
$
temp
<<
16
);
}
}
//for each iterations
//return the keys we've created
return
$
keys
;
}
//end of des_createKeys
/*
////////////////////////////// TEST //////////////////////////////
function stringToHex ($s) {
$r = "0x";
$hexes = array ("0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f");
for ($i=0; $i<strlen($s); $i++) {$r .= ($hexes [(ord($s{$i}) >> 4)] . $hexes [(ord($s{$i}) & 0xf)]);}
return $r;
}
echo "<PRE>";
$key = "this is a 24 byte key !!";
$message = "This is a test message";
$ciphertext = des ($key, $message, 1, 0, null);
echo "DES Test Encrypted: " . stringToHex ($ciphertext);
$recovered_message = des ($key, $ciphertext, 0, 0, null);
echo "\n";
echo "DES Test Decrypted: " . $recovered_message;
*/
?
>
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sat, Apr 4, 3:31 AM (1 d, 13 h)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
21/e1/83075858dab55b4fa8b57cf382ec
Default Alt Text
des.inc (17 KB)
Attached To
Mode
R113 roundcubemail
Attached
Detach File
Event Timeline