日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

TEA通讯加密

發布時間:2024/6/21 综合教程 39 生活家
生活随笔 收集整理的這篇文章主要介紹了 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 ;
  }
}

總結

以上是生活随笔為你收集整理的TEA通讯加密的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。