前言:
现在小伙伴们对“tea加密算法c语言实现”大致比较看重,朋友们都需要了解一些“tea加密算法c语言实现”的相关知识。那么小编同时在网上网罗了一些关于“tea加密算法c语言实现””的相关资讯,希望小伙伴们能喜欢,我们一起来了解一下吧!近期笔者在某环境监测设备的新项目中,客户询问到关于如何对数据和资源进行加密的问题。环境监测设备主要运用于冷链生鲜、药物、危险品运输、农业生产、养殖业等,帮助用户监测环境的变化,包括了温度、湿度与光照情况。
环境监测设备主要运用了物联网的传感技术,通过各种传感器将数据通过通信模块和网络进行传递,云息通信的环境监测设备在针对数据加密的问题主要运用了TEA加密算法,该算法具有较强的抗差分分析能力,且简单高效。
TEA加密,算法简单,容易实现,主要通过移位和异或实现数据的加密,对算力需求不高,很适合再嵌入式系统中使用。TEA算法利用不断增加的Delta(黄金分割率)值作为变化,使得每轮的加密是不同,该加密算法的迭代次数可以改变,建议的迭代次数为32轮。加密使用一组128bit的密钥进行加密,解密的时候同样需要密钥解密。
加密算法如下:
#define MX (z>>5y<<2)+(y>>3z<<4)(sumy)+(k[p&3e]z)
#define DELTA 0x9e3779b9
#define S_LOOPTIME 1 //5
//TEA密钥
unsigned char TEA_key[16]=
{
0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10
};
/*
*key maybe 128bit =16 Bytes.
buf maybe BLOCK_SIZE
/
void btea_encrypt( unsigned char buf, unsigned int BLOCK_SIZE,unsigned char key )
{
unsigned char n=BLOCK_SIZE/4;
unsigned long *v=(unsigned long *)buf;
unsigned long *k=(unsigned long *)key;
unsigned long z = v[n - 1],y = v[0],sum = 0,e ;
unsigned char p,q ;
// Coding Part
q = S_LOOPTIME + 52 / n ;
while ( q-- > 0 )
{
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;
}
}
同样从事相关设备开发的工作人员,在面对数据资源加密的问题时,可采用以上内容进行参考。
标签: #tea加密算法c语言实现 #tea算法java #tea算法加密