#define DELTA 0x9e3779b9
#define MX (((z>>5^y<<2) + (y>>3^z<<4)) ^ ((sum^y) + (key[(p&3)^e] ^ z)))
#define XXTEA_ENCODE_MODE 0
#define XXTEA_DECODE_MODE 1
void xxtea(unsigned int *v, int n, const unsigned int key[], int mode)
{
unsigned int y, z, sum;
unsigned int p, rounds, e;
if(n <= 1) return;
if(mode == XXTEA_ENCODE_MODE) { /* Coding Part */
rounds = 6 + 52/n;
sum = 0;
z = v[n - 1];
do {
sum += DELTA;
e = (sum >> 2) & 3;
for(p = 0; p < n - 1; p++) {
y = v[p + 1];
z = v[p] += MX;
}
y = v[0];
z = v[n - 1] += MX;
}while(--rounds);
} else if(mode == XXTEA_DECODE_MODE) { /* Decoding Part */
rounds = 6 + 52/n;
sum = rounds * DELTA;
y = v[0];
do {
e = (sum >> 2) & 3;
for(p = n - 1; p > 0; p--) {
z = v[p - 1];
y = v[p] -= MX;
}
z = v[n - 1];
y = v[0] -= MX;
sum -= DELTA;
}while(--rounds);
}
return;
}
分享到:
相关推荐
XXTEA算法的C语言实现,内含测试代码,编译后可直接运行
以上就是DH算法和XXTEA算法在Java中的基本实现。在实际应用中,还需要考虑安全性、错误处理、数据格式转换等问题。在提供的压缩包文件"DH_xxtea_out"中,可能包含了实现这些功能的Java源代码和示例,可以直接引用和...
“微型加密算法(TEA)及其相关变种(XTEA,Block TEA,XXTEA)都是分组加密算法,它们很容易被描述,实现也很简单(典型的几行代码)。 TEA 算法最初是由剑桥计算机实验室的 David Wheeler 和 Roger Needham 在 ...
7. **C实现(xxtea.c.zip)**:C语言是一种基础的系统编程语言,它的XXTEA实现简洁且高效,适用于嵌入式系统和其他需要轻量级加密的场景。 8. **PHP实现(xxtea_php.txt)**:PHP是服务器端的脚本语言,常用于Web...
在提供的压缩包中,有两个关键文件,分别是`xxtea.cs`和`xxtea.js`,分别代表XXTEA算法的C#和JavaScript实现。C#是一种广泛用于开发Windows桌面应用、Web应用以及游戏的编程语言,而JavaScript则主要应用于网页和...
CentOS 可以运行,需要的可以在此之上修改
TEA(Tiny Encryption Algorithm)是一种小型的对称加密解密算法,支持128位密码,与BlowFish一样TEA每次只能加密/解密8字节数据。TEA特点是速度快、效率高,实现也非常简单。由于针对TEA的攻击不断出现,所以TEA也发展出...
XXTEA(Extreme eXtended TEA,极度扩展的TEA)是一种对称加密算法,由David Wheeler和Roger Needham在1994年提出,是对Tiny Encryption Algorithm(TEA)的改进版本。TEA虽然简洁,但在某些情况下可能不够安全,而...
xxtea-java, Java的XXTEA加密算法库 用于 Java 的 XXTEA 简介XXTEA是一种快速安全的加密算法。 这是一个用于Java的XXTEA库。它与原始的XXTEA加密算法不同。 它加密和解密字节 [] 而不是 32bit 整数 array,键也
前段时间由于要用C++解密一个C#用xxtea加密过的文件,由于网上资源稀缺,最终导致自己重写+修改了一下C++_xxtea 的代码,我已经vs2010测试过了,最近又修改了一下,可以支持中文及中文标点加解密,与C#通用。...
"XXtea"这个文件可能是实现XXtea算法的源代码或者编译后的库文件,具体使用方式需要查看源代码或相关文档来了解。在使用过程中,确保遵循开源许可(如提供的"License"标签所示),并注意版权问题。
C语言tea,xtea,xxtea,RC4,base64,base64自定义字符表加解密实现的头文件,已封装好。可直接调用函数使用
《一种适用于RFID读写器的加密算法及其实现》 随着RFID(Radio Frequency Identification)技术的广泛应用,RFID读写器的安全性问题日益凸显。RFID系统因其无线通信特性,面临着数据被窃取、篡改等安全隐患。为解决...
XXTEA在PHP中的实现通常是以扩展的形式存在,如提供的“xxtea-pecl-master”文件,这是一个用于PHP的XXTEA加密算法扩展源码。 **1. XXTEA算法原理** XXTEA算法基于四轮循环操作,对32位整数进行处理。其基本流程...
XXTEA算法是一种高效、简洁的微积分加密算法,由David Wheeler和Roger Needham于1994年提出,主要用于短数据...在VS2010环境下编译的“hello”程序,可能包含了XXTEA算法的实现,可以用来学习和理解该算法的工作原理。
XXTEA算法适用于各种编程语言,包括C#,在这里我们主要关注XXTEA在C#中的实现。 XXTEA算法基于四字节的块进行操作,通过一系列非线性变换对数据进行加密。它的核心是通过迭代循环进行加密,每次迭代都会对数据进行...
1. **简单高效**:XXTEA算法的实现相对简单,计算过程快速,适合资源有限的移动设备。 2. **安全性高**:经过改进后的XXTEA算法,相比原始的TEA算法,其安全性有了显著提高,不容易受到已知的攻击。 3. **块加密**...
在Java中实现XXTEA加解密算法,通常需要以下几个关键步骤: 1. **定义XXTEA算法的基本参数**:XXTEA算法基于四个字(32位)的块进行操作,因此需要将输入的数据按照四字节边界进行划分。同时,它使用两个密钥参数`...
2. `XXTEA.m`:实现文件,包含了XXTEA算法的具体实现逻辑,与头文件相对应。 3. `示例`或`Demo`目录:可能包含了一个简单的示例项目,演示如何在Objective-C代码中使用XXTEA类进行数据加密和解密。 使用这个...
XXTEA算法是一种迭代对称加密算法,其特点包括简单的结构,易于硬件实现,并且软件实现代码短小,具有良好的可移植性。这些特点使得XXTEA非常适合用于资源受限的嵌入式RFID系统。XXTEA算法的加密轮次取决于数据长度...