您的位置 首页 硬件

STM32单片机的TEA加密通讯规划

STM32单片机的TEA加密通信设计-在项目中单片机会与服务器进行网络通讯。需要对通讯加密,我选择了TEA加密算法。

*说明:TEA加密解密算法

*TEA(TinyEncryptionAlgorithm)是一种简单高效的加密算法,以加密解密速度快,

*实现简单著称。

*算法很简单,TEA算法每一次可以操作64-bit(8-byte),采用128-bit(16-byte)作为key,

*算法采用迭代的形式,

*推荐的迭代轮数是64轮,最少32轮。

环境:

主机:WIN7

开发环境:MDK4.72

单片机STM32

阐明:

在项目中单片机会与服务器进行网络通讯。需要对通讯加密,我挑选了TEA加密算法。

*阐明:TEA加密解密算法

*TEA(TInyEncrypTIonAlgorithm)是一种简略高效的加密算法,以加密解密速度快,

*完成简略著称。

*算法很简略,TEA算法每一次能够操作64-bit(8-byte),选用128-bit(16-byte)作为key,

*算法选用迭代的方式,

*引荐的迭代轮数是64轮,最少32轮。

**********************************************************************/

#ifndef_TEA_H_

#define_TEA_H_

/*********************************************************************

*头文件

**********************************************************************/

#include“header.h”

/*********************************************************************

*函数

**********************************************************************/

/*********************************************************************

*tea加密

*参数:v:要加密的数据,长度为8字节

*k:加密用的key,长度为16字节

**********************************************************************/

staTIcvoidtea_encrypt(uint32_t*v,uint32_t*k);

/*********************************************************************

*tea解密

*参数:v:要解密的数据,长度为8字节

*k:解密用的key,长度为16字节

**********************************************************************/

staTIcvoidtea_decrypt(uint32_t*v,uint32_t*k);

/*********************************************************************

*加密算法

*参数:src:源数据,所占空间有必要为8字节的倍数。加密完成后密文也寄存在这

*size_src:源数据巨细,单位字节

*key:密钥,16字节

*回来:密文的字节数

**********************************************************************/

uint16_tencrypt(uint8_t*src,uint16_tsize_src,uint8_t*key);

/*********************************************************************

*解密算法

*参数:src:源数据,所占空间有必要为8字节的倍数。解密完成后明文也寄存在这

*size_src:源数据巨细,单位字节

*key:密钥,16字节

*回来:明文的字节数,假如失利,回来0

**********************************************************************/

uint16_tdecrypt(uint8_t*src,uint16_tsize_src,uint8_t*key);

#endif

tea.c

/*********************************************************************

*TEA算法主文件

*(c)copyright2013,jdh

*AllRightReserved

*文件名:hash.c

*程序员:jdh

**********************************************************************/

/*********************************************************************

*头文件

**********************************************************************/

#include“tea.h”

/*********************************************************************

*函数

**********************************************************************/

/*********************************************************************

*tea加密

*参数:v:要加密的数据,长度为8字节

*k:加密用的key,长度为16字节

**********************************************************************/

staticvoidtea_encrypt(uint32_t*v,uint32_t*k)

{

uint32_ty=v[0],z=v[1],sum=0,i;

uint32_tdelta=0x9e3779b9;

uint32_ta=k[0],b=k[1],c=k[2],d=k[3];

for(i=0;i《32;i++)

{

sum+=delta;

y+=((z《《4)+a)^(z+sum)^((z》》5)+b);

z+=((y《《4)+c)^(y+sum)^((y》》5)+d);

}

v[0]=y;

v[1]=z;

}

/*********************************************************************

*tea解密

*参数:v:要解密的数据,长度为8字节

*k:解密用的key,长度为16字节

**********************************************************************/

staticvoidtea_decrypt(uint32_t*v,uint32_t*k)

{

uint32_ty=v[0],z=v[1],sum=0xC6EF3720,i;

uint32_tdelta=0x9e3779b9;

uint32_ta=k[0],b=k[1],c=k[2],d=k[3];

for(i=0;i《32;i++)

{

z-=((y《《4)+c)^(y+sum)^((y》》5)+d);

y -= ((z 《《 4) + a) ^ (z + sum) ^ ((z 》》 5

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/yingjian/346226.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部