龙空技术网

「技术科普」云息环境监测设备中关于TEA加密算法

云息通信技术有限公司 273

前言:

现在小伙伴们对“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算法加密