- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 DCPCrypt 包(最新版本),并且正在尝试使用来自 NIST 分发的 AES 已知答案测试 (KAT) 向量的测试值在 Delphi2007 中进行 AES/Rijndael CBC 编码(128 位 block ,256 位 key )。一个样本测试向量:
KEY = 0000000000000000000000000000000000000000000000000000000000000000
IV = 00000000000000000000000000000000
PLAINTEXT = 80000000000000000000000000000000
CIPHERTEXT = ddc6bf790c15760d8d9aeb6f9a75fd4e
下面的代码返回:
Cyphertext (bytes): 58 215 142 114 108 30 192 43 126 191 233 43 35 217 236 52
Cyphertext (hex): 3AD78E726C1EC02B7EBFE92B23D9EC34
Cyphertext (base64): OteOcmwewCt+v+krI9nsNA==
这显然是不正确的。
procedure TFrmKATVectors.TestData(Key,IV,PlainText: String);
var
InBuf,OutBuf: TestBuffer;
KeyBuf: KeyBuffer;
IVBuf: IVBuffer;
l,i: Integer;
Bytes,
SOut: String;
begin
Memo1.Lines.Add('Key: ' + Key);
Memo1.Lines.Add('IV: ' + IV);
Memo1.Lines.Add('Plaintext: ' + Plaintext);
l := Length(Key) DIV 2;
for i := 1 to l do KeyBuf[i] := HexToInt(Copy(Key,2*(i-1)+1,2));
l := Length(IV) DIV 2;
for i := 1 to l do IVBuf[i] := HexToInt(Copy(IV,2*(i-1)+1,2));
l := Length(PlainText) DIV 2;
for i := 1 to l do InBuf[i] := HexToInt(Copy(PlainText,2*(i-1)+1,2));
DCP_rijndael1.Init(KeyBuf,32,@IVBuf);
DCP_rijndael1.EncryptCBC(InBuf,OutBuf,TestBufSize);
SOut := '';
for i := 1 to Length(OutBuf) do
begin
SOut := SOut + Chr(OutBuf[i]);
Bytes := Bytes + IntToStr(OutBuf[i]) + ' ';
end;
Memo1.Lines.Add('Cyphertext (bytes): ' + Bytes);
Memo1.Lines.Add('Cyphertext (hex): ' + StringToHex(SOut));
Memo1.Lines.Add('Cyphertext (base64): ' + Base64EncodeStr(SOut));
Memo1.Lines.Add('');
end;
我正在打电话
TestData('0000000000000000000000000000000000000000000000000000000000000000',
'00000000000000000000000000000000', '80000000000000000000000000000000');
与
const
TestBufSize = 16;
type
TestBuffer = packed Array[1..TestBufSize] of Byte;
KeyBuffer = packed Array[1..32] of Byte;
IVBuffer = packed Array[1..16] of Byte;
考虑到我的测试数据的长度,我正在避免任何填充问题。我究竟做错了什么?有什么建议吗?
(不,您不必重新计算参数字符串的长度 - 我这样做了好几次。)
最佳答案
Init 方法中的 key 大小参数以位为单位 - 如方法注释所述:
Do key setup based on the data in Key, size is in bits
您正在使用 KeySize = 32 位计算 AES,这是无效的。
因此,您计算最低的可用 key 大小,即 128。返回的值对于 128 位来说是正确的 - 请参阅 http://csrc.nist.gov/groups/STM/cavp/documents/aes/AESAVS.pdf第 20 页。
尝试指定 256 位作为 key 大小:
DCP_rijndael1.Init(KeyBuf,256,@IVBuf);
关于delphi - DCPCrypt/Delphi 未正确编码 Rijndael,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8313992/
我使用函数 EncryptStringToBytes 将纯文本加密为字节数组,并且最后将字节数组转换为字符串并返回。 我使用另一个函数将加密文本解密为纯文本。 我尝试用 RC2 对文本进行打乱,但它引
我正在考虑切换到将 session 数据存储在加密的 cookie 中,而不是在我的服务器上的某个地方。虽然这将导致每个请求使用更多带宽 - 它将节省额外的数据库服务器负载和存储空间。 无论如何,我计
我在使用 BouncyCaSTLe API for Java 实现 Rijndael 加密时遇到问题。 当我执行cipher.doFinal(inputTextBytes, intOutOff);时,
我正在使用发现的 DCPcrypt 库 here . 这是一个加密字符串的小代码 InitializationVector: AnsiString; const Key: Ansistring = '
我正在尝试模仿 http://www.hanewin.net/encrypt/aes/aes-test.htm 的 Rijndael (AES) 加密在Python3. 具体来说,当我使用以下输入时:
我正在一个类中组织一些非常基本的对称加密/解密代码以供将来使用。我能够成功加密和解密...只是有一个小问题。 这是我从一个流中读入并加密/解密到另一个流的代码: public void Encrypt
我正在尝试使用 Rijndael 加密来加密图像文件,我一定是做错了什么,因为解密的文件在文件的前面带有额外的数据,最后可能还有一点额外的数据。我对这种加密算法还很陌生,所以我很确定我只是遗漏了一些简
我正在研究 AES-256-CBC 的实现(如下所示),这将用于客户端到数据库的设置。 key 存储在本地,此方案的目的是在数据库内容泄漏时使某些值不可读。 由于IV是固定长度的,所以我打算将密文设为
我正在尝试使用 Rijndael 或 Aes 以及下面的代码来加密/解密字符串。 public class Crypto { private const string defaultVecto
我想使用 C# 研究 Rijndael 算法。有人可以帮我解决这个问题吗? 最佳答案 我假设您指的是 Rijndael 加密算法 - 在这种情况下 RinjdaelManaged会有用的。 MSDN
您好,我正在尝试通过 Rijaendal 加密/解密字符串。我根本无法弄清楚为什么解密会失败。我总是以不正确的填充错误结束。让我失望的一件事是我作为 HEX 数组返回的加密结果。它的长度为 14 个字
我有一个进行 Rijndael 加密的 PHP 代码的引用。我想将它转换为java代码,我尝试了几个例子,但没有一个对我有用。这是 php 代码: $initialisationVector = ha
我多次使用以下 Rijndael 代码进行加密。但是为什么它不能加密一个 4.2 GB 的 ISO 文件呢?事实上,我的电脑有 16GB 内存,应该不是内存问题。我使用 Windows 7 旗舰版。代
只有部分字符串被解密,我认为这与我的编码有关。 这是发生了什么: string s = "The brown fox jumped over the green frog";
我尝试了来自SO和整个网络的许多答案,但仍然没有成功。 我使用以下tool进行加密。 text to encrypt: tom key: exo123exo1exo123 input (textfie
我有一个编码和解码字符串的安全类,但是当我尝试解码时 - 出现了问题。 这是我的安全类: class Security { public static String encrypt(Strin
我写的一些软件使用了.Net4.0的Rijndael算法来加密和解密许可证信息。 问题如下:该程序生成一个字符串,该字符串被转换为 byte[]。这个 byte[] 然后用 Rijndael 加密成另
我在一个网站上找到了这段代码 private void EncryptFile(string inputFile) { string password
当我选择密码加密时,我发现Rijndael算法是最好的加密之一,无法通过暴力破解。 所以我选择了Rijndael算法对用户密码进行加密。 现在我已经确定,哈希(不可逆)比加密(可逆)更安全[如果我错了
我有一些代码可以用 Rijndael 解密密码 public static string DecryptPassword(string encrypted) { using (MemorySt
我是一名优秀的程序员,十分优秀!