zoukankan      html  css  js  c++  java
  • TEA通讯加密

            TEA通讯加密

    在通讯中总是包含一些重要的数据,一旦被人抓包复制这些数据,无疑会产生巨大的损失,所以出现了许多的算法,比如DES、TEA等。

    其中这个TEA加密我发现很适合手上的项目,也非常适合单片机的通讯加密。只是很可惜在与前端的对接中,前端技术员暂时无法实现,因此自己定义了一套简单的类似的加密法,但方法与这个相同。

    主要是由PC端向MCU端发起操作,MCU生成一个随机数发给PC,PC接收到随机数后通过加密函数生成密文,随机数在一定期限内有效。

    以下代码就是从此处转载,本人在STM32F0中亲验可行,非常好的代码值得推荐http://www.51hei.com/bbs/dpj-137887-1.html

    /*******************
      TEA加密解密算法
    *******************/
    #define DATA_LEN 32
    
    #define MX (z>>5^y<<2)+(y>>3^z<<4)^(sum^y)+(k[p&3^e]^z)
    #define DELTA 0x9e3779b9
    #define S_LOOPTIME   1                                //5
    #define BLOCK_SIZE   DATA_LEN                //PAGE_SIZE,根据你所要加密的数据包长度修改此参数(单位:字节)
    
    unsigned char TEA_key[16]=
    { 
      0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
      0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10
    };
    
    //数据缓冲区
    unsigned char TX_buffer[DATA_LEN];
    unsigned char RX_buffer[DATA_LEN];
    
    
    /*加密时使用函数, buf里面的内容就是加密后的数据,key是加密密钥*/
    void btea_encrypt( unsigned char* buf, 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;
      }
    }
    
    /*解密时使用函数, buf里面的内容就是解密后的数据,key是解密密钥*/
    void btea_decrpyt( unsigned char* buf, 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 ;
    
      //Decoding Part...
      q = S_LOOPTIME + 52 / n ;
      sum = q * DELTA ;
      while ( sum != 0 )
      {
        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 ;
      }
    }
  • 相关阅读:
    奋斗了一晚上,搞定了Ant
    我很成功,我很失败
    管理复杂性
    Rapid framework(SSH)数据流概述
    Strtus2 Convention Plugin学习(转)
    16X16 经典silk图标 (famfamfam.com)
    v512 Oracle数据库实用教程 演示用ppt(转pdf)
    RapidFramework使用Oracle的步骤
    oracle 找出最耗资源的sql (dolphin_ygj)
    jquery validate 中文化
  • 原文地址:https://www.cnblogs.com/wcw12580/p/12611898.html
Copyright © 2011-2022 走看看