[英]Decryption from encryption method
我需要為舊代碼重新編寫一種解密方法,不幸的是,由於我們只能訪問加密,因此原來的解密方法已經丟失。
type
TintArray = array [0 .. 1] of Cardinal;
TKeyArray = Array [0 .. 3] of Cardinal;
const
KeyArray: TKeyArray = (858945348, 1144282739, 828794915, 556884274);
procedure Encipher(var V, W: TintArray);
var
y, z, sum, delta, a, b, c, d, n: Cardinal;
iCounter: Integer;
begin
y := V[0];
z := V[1];
sum := 0;
delta := $9E3779B9; // 2654435769;//0x9E3779B9;
a := KeyArray[0];
b := KeyArray[1];
c := KeyArray[2];
d := KeyArray[3];
n := 32;
for iCounter := n downto 1 do begin
sum := sum + delta;
y := y + (((z shl 4) + a) xor (z + sum) xor ((z shr 5) + b));
z := z + (((y shl 4) + c) xor (y + sum) xor ((y shr 5) + d));
end;
W[0] := y;
W[1] := z;
end;
我已經嘗試了一些平凡的事情,例如將所有的“ +”更改為“-”,但是我並不抱有太大希望,因為我實際上根本不了解代碼。
這是微小的加密算法(TEA)。 在Wikipedia上查看。
您的解密例程應該是這樣的(遵循您的命名約定等):
procedure Decipher(var V, W: TintArray);
var
y, z, sum, delta, a, b, c, d, n: Cardinal;
iCounter: Integer;
begin
y := V[0];
z := V[1];
sum := $C6EF3720;
delta := $9E3779B9; // 2654435769;//0x9E3779B9;
a := KeyArray[0];
b := KeyArray[1];
c := KeyArray[2];
d := KeyArray[3];
n := 32;
for iCounter := n downto 1 do begin
z := z - (((y shl 4) + c) xor (y + sum) xor ((y shr 5) + d));
y := y - (((z shl 4) + a) xor (z + sum) xor ((z shr 5) + b));
sum := sum - delta;
end;
W[0] := y;
W[1] := z;
end;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.