當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]  各位大俠在做數(shù)據(jù)傳輸時(shí),有沒有考慮過把數(shù)據(jù)加密起來進(jìn)行傳輸,若在串口或者無線中把所要傳的數(shù)據(jù)加密起來,豈不是增加了通信的安全性。常用的加密解密算法比如DES、RSA等,受限于單片機(jī)的內(nèi)存和運(yùn)算速度,實(shí)現(xiàn)

  各位大俠在做數(shù)據(jù)傳輸時(shí),有沒有考慮過把數(shù)據(jù)加密起來進(jìn)行傳輸,若在串口或者無線中把所要傳的數(shù)據(jù)加密起來,豈不是增加了通信的安全性。常用的加密解密算法比如DES、RSA等,受限于單片機(jī)的內(nèi)存和運(yùn)算速度,實(shí)現(xiàn)起來比較困難,但一種叫TEA的加密算法特別適合單片機(jī)使用。

  TEA(Tiny Encryption Algorithm)是一種簡(jiǎn)單高效的加密算法,以加密解密速度快,實(shí)現(xiàn)簡(jiǎn)單著稱。算法很簡(jiǎn)單,TEA算法每一次可以操作64-bit(8-byte),采用128-bit(16-byte)作為key,算法采用迭代的形式,推薦的迭代輪數(shù)是64輪,最少32輪。目前我只知道QQ一直用的是16輪TEA。

  我之前做過一個(gè)數(shù)字的無線對(duì)講機(jī),把語音數(shù)據(jù)加密后發(fā)送,雙方事先規(guī)定好公共的密鑰,就可以進(jìn)行加密和解密了。至于TEA算法速度,在我看來確實(shí)很快,我當(dāng)時(shí)用的是16位的msp430單片機(jī),晶振只有6M,每秒鐘大概可以進(jìn)行兩三百次加密和解密的操作(一次加密和解密32字節(jié))。

  說到加密,最簡(jiǎn)單的方式就是把要發(fā)送的數(shù)據(jù)和同樣長(zhǎng)度的密碼進(jìn)行異或運(yùn)算,得到新的數(shù)據(jù)就是加密后的數(shù)據(jù),然后,接收方把加密數(shù)據(jù)和密碼進(jìn)行異或就能得到原始數(shù)據(jù)。但這種異或的方法安全性如何,我也說不清楚。

  下面上傳了c++實(shí)現(xiàn)的TEA算法,可以在vc里面調(diào)試看看。我把它改了改,讓它適合單片機(jī)使用,下面的TEA.h和TEA.c可以包含在你的工程里面。使用時(shí),根據(jù)你所要加密的數(shù)據(jù)包長(zhǎng)度修改宏定義BLOCK_SIZE,密鑰的長(zhǎng)度是16字節(jié)。數(shù)據(jù)和密鑰都是存放在數(shù)組里面的,比如:



//TEA密鑰

unsigned char TEA_key[16]=

{

0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,

0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10

};


//數(shù)據(jù)緩沖區(qū)

unsigned char TX_buffer[32];

unsigned char RX_buffer[32];


加密時(shí)使用函數(shù):

btea_encrypt(TX_buffer,TEA_key); //TEA加密

這樣,數(shù)組TX_buffer里面的新內(nèi)容就是加密后的數(shù)據(jù)。


接收到的密文數(shù)據(jù)存放在RX_buffer里面,調(diào)用下面函數(shù):

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 S_LOOPTIME 1 //5

#define BLOCK_SIZE 31 //PAGE_SIZE,根據(jù)你所要加密的數(shù)據(jù)包長(zhǎng)度修改此參數(shù)(單位:字節(jié))


/*

*key maybe 128bit =16 Bytes.

*buf maybe BLOCK_SIZE

*/


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;

}

}



/*

*key maybe 128bit =16Bytes.

*buf maybe BLOCK_SIZE

inbuf == outbuf == buf

*/


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 ;

}

}




#ifndef __TEA_h__

#define __TEA_h__



//TEA加密函數(shù)

void btea_encrypt( unsigned char* buf, unsigned char* key );

//TEA解密函數(shù)

void btea_decrpyt( unsigned char* buf, unsigned char* key );



#endif



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉