TEA中的加密和解密结果不相同
Encryption and decryption results are not same in TEA
我已经在C++中实现了TEA。以下是代码:
#include <stdio.h>
#include <iostream>
#include <iostream>
using namespace std;
int main()
{
unsigned long y=24,z=32, sum=0,
delta=0x9e3779b9, n=16 ;
int k[4] = { 0x28, 0xc0, 0x20, 0xd0 };
unsigned long v[2] = {0,0};
cout<<"original y is "<< y<<". original z is "<<z<<endl;
while (n-->0)
{
sum += delta ;
y += ((z<<4)+k[0]) ^ (z+sum) ^ ((z>>5)+k[1]) ;
z += ((y<<4)+k[2]) ^ (y+sum) ^ ((y>>5)+k[3]) ;
}
v[0]=y ; v[1]=z ;
cout<<"encrypted y is "<< v[0]<<". encrypted z is "<<v[1]<<endl;
n=16;
y=v[0];
z=v[1];
delta=0x9e3779b9 ;
sum=delta<<5 ;
/* start cycle */
while (n-->0)
{
z-= ((y<<4)+k[2]) ^ (y+sum) ^ ((y>>5)+k[3]) ;
y-= ((z<<4)+k[0]) ^ (z+sum) ^ ((z>>5)+k[1]) ;
sum-=delta ;
}
v[0]=y ; v[1]=z ;
cout<<"decrypted y is "<< v[0]<<". decrypted z is "<<v[1]<<endl;
getchar();
return 0;
}
但最终,结果并不相同,即解密的值与原始输入(y
和z
)不同。请指出我看不见的错误。
您将n
设置为16,而维基百科上的示例实现运行循环32次。
如果我在您的代码中将n
更改为32,它会起作用:在Coliru 上实时查看
sum = n * delta
将sum
计算为对应于delta * 32
的delta << 5
。这适用于默认值n = 32
,但您将n
减少为16
,而没有修复sum
的计算。将sum=delta<<5;
替换为sum = delta * n
。
还要注意,减少循环次数会削弱对密码分析的抵抗力。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- valgrind-hellgrind与泄漏检查的结果不同
- 用C++20 fmt限制结果的总大小
- 如何返回一个类的两个对象相加的结果
- AES加密到解密未正确输出
- 为什么这不是解密
- 使用QProcess执行命令,并将结果存储在QStringList中
- 如果我std::dynamic_pointer_cast并且底层dynamic_cast的结果为null,那么返回的sh
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 序列化,没有库的整数,得到奇怪的结果
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 在更改for循环的第三部分后,未使用for循环结果
- 使用++运算符会导致意外的结果
- 为什么在逗号分隔符上下文中将预增量的结果强制转换为void
- C++Brute Force攻击函数不会返回结果
- 你好。。。id_public变量不应该给出结果为 81 和 86 吗?为什么它为两个派生类占用不同的内存位置?
- 算术运算的结果类似于:C浮点变量中的1/3
- ";结果类型必须是可从输入范围的值类型""构造的;创建std::vector时
- 密码登录程序将永远循环并显示不正确的结果
- TEA中的加密和解密结果不相同