各位大侠在做数据传输时,有没有考虑过把数据加密起来进行传输,若在串口或者无线中把所要传的数据加密起来,岂不是增加了通信的安全性。常用的加密解密算法比如DES、RSA等,受限于单片机的内存和运算速度,实现起来比较困难,但一种叫TEA的加密算法特别适合单片机使用。
  TEA(Tiny Encryption Algorithm)是一种简单高效的加密算法,以加密解密速度快,实现简单著称。算法很简单,TEA算法每一次可以操作64-bit(8-byte),采用128-bit(16-byte)作为key,算法采用迭代的形式,推荐的迭代轮数是64轮,最少32轮。目前我只知道QQ一直用的是16轮TEA。
  我之前做过一个数字的无线对讲机,把语音数据加密后发送,双方事先规定好公共的密钥,就可以进行加密和解密了。至于TEA算法速度,在我看来确实很快,我当时用的是16位的msp430单片机,晶振只有6M,每秒钟大概可以进行两三百次加密和解密的操作(一次加密和解密32字节)。
  说到加密,最简单的方式就是把要发送的数据和同样长度的密码进行异或运算,得到新的数据就是加密后的数据,然后,接收方把加密数据和密码进行异或就能得到原始数据。但这种异或的方法安全性如何,我也说不清楚。
  下面上传了c++实现的TEA算法,可以在vc里面调试看看。我把它改了改,让它适合单片机使用,下面的TEA.h和TEA.c可以包含在你的工程里面。使用时,根据你所要加密的数据包长度修改宏定义BLOCK_SIZE密钥的长度是16字节。数据和密钥都是存放在数组里面的,比如:

//TEA密钥
unsigned ]=
{
    0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
    0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10
};

//数据缓冲区
unsigned ];
unsigned ];

加密时使用函数:
btea_encrypt(TX_buffer,TEA_key);      //TEA加密
这样,数组TX_buffer里面的新内容就是加密后的数据。

接收到的密文数据存放在RX_buffer里面,调用下面函数:
decrpyt(RX_buffer,TEA_key);      //TEA解密
就能得到之前的明文。

/*******************
  TEA加密解密算法
*******************/

#include "TEA.h"

#define MX                (z>>5^y<<2)+(y>>3^z<<4)^(sum^y)+(k[p&3^e]^z)
#define DELTA             0x9e3779b9

#define BLOCK_SIZE        31       //PAGE_SIZE,根据你所要加密的数据包长度修改此参数(单位:字节)

/*
*key  maybe 128bit =16 Bytes.
*buf  maybe BLOCK_SIZE
*/

void btea_encrypt( unsigned char* buf, unsigned char* key )
{
    unsigned ;
    unsigned long *v=(unsigned long *)buf;
    unsigned long *k=(unsigned long *)key;
    unsigned ],y = v[],sum = ,e ;
    unsigned char p,q ;
    // Coding Part 

    q = S_LOOPTIME +  / n ;
     )
    {
        sum += DELTA ;
        e = sum >>  &  ;
         ; p < n -  ; p++ )
          y = v[p + ],
          z = v[p] += MX;
          y = v[] ;
        z = v[n - ] += MX;
    }
}

/*
*key  maybe 128bit =16Bytes.
*buf  maybe BLOCK_SIZE
inbuf == outbuf == buf
*/

void btea_decrpyt( unsigned char* buf, unsigned char* key )
{
    unsigned ;
    unsigned long *v=(unsigned long *)buf;
    unsigned long *k=(unsigned long *)key;
    unsigned ],y = v[],sum = ,e ;
    unsigned char  p,q ;

    //Decoding Part...
    q = S_LOOPTIME +  / n ;
    sum = q * DELTA ;
     )
    {
        e = sum >>  &  ;
         ; p >  ; p-- )
            z = v[p - ],
            y = v[p] -= MX;
            z = v[n - ] ;
        y = v[] -= MX;
        sum -= DELTA ;
    }
}
#ifndef __TEA_h__
#define __TEA_h__

//TEA加密函数
void btea_encrypt( unsigned char* buf, unsigned char* key );
//TEA解密函数
void btea_decrpyt( unsigned char* buf, unsigned char* key );

#endif

最新文章

  1. iOS动画效果和实现
  2. [转]Travis Ci的最接底气的中文使用教程
  3. 【数据压缩】LZ77算法原理及实现
  4. 带你秒学JavaScript
  5. github仓库的克隆、修改、上传方法(图)
  6. 日期加减js,天数组增加,日期自动修改
  7. 如何用C#获得文件信息以及扩展信息
  8. Netty版本升级血泪史之线程篇
  9. HNC-局部联想脉络
  10. html5 input的type属性启动数字输入法
  11. 《Pointers On C》读书笔记(第四章 语句)
  12. CodeForces 618C CodeForces 618C
  13. HTML 基础学习笔记
  14. 如何在mysql客户端即mysql提示符下执行操作系统命令
  15. Fragment+Viewpaager
  16. elementUI的table组件实现setCurrentRow的滚动条定位效果
  17. 微信小程序开发3之保存数据及页面跳转
  18. Atitit 数据库view视图使用推荐规范与最佳实践与方法
  19. 谷歌开源的TensorFlow Object Detection API视频物体识别系统实现(一)[超详细教程] ubuntu16.04版本
  20. DB通用类:SQL Server 通用类库

热门文章

  1. 10个经典的Android开源项目(附源码包)
  2. Codeforces 372B Counting Rectangles is Fun
  3. 再不升级你就Out了 Windows8.1安装实录
  4. 《Programming WPF》翻译 第5章 4.元素类型样式
  5. 【剑指offer】面试题29:数组中出现次数超过一半的数字
  6. Install Cocos2d-x v3.3 on Ubuntu 14.04 &amp; Ubuntu 14.10(转)
  7. pod setup 报CocoaPods was not able to update the `master` repo 错误解决办法
  8. Java遍历Map对象的四种方法
  9. python之路-模块安装 paramiko
  10. PC-HTML5-搜索框