現(xiàn)在的MCU程序可能別人花幾百塊錢就能破解,為了防止大家的程序不被剽竊,今天給大家分享點(diǎn)加密的內(nèi)容。
一、常見加密方法
本節(jié)不講加密具體實(shí)現(xiàn)算法,只講常見加密方法。
1.程序?qū)懕Wo(hù)
這種方法是最常見,也是最簡單的一種?,F(xiàn)在的MUC基本都有寫保護(hù)功能,但是這種容易被人破解。
2.燒斷數(shù)據(jù)總線
這個(gè)方法聽起來不錯,但有損壞的風(fēng)險(xiǎn),同樣也能破解。
3.軟件加密
是一些防止別人讀懂程序的方法,單一的這種方法不能防止別人全盤復(fù)制,須配合其他的加密算法。
4.添加外部硬件電路的加密方法
這個(gè)方法效果看起來比較好,但會增加成本。
5.芯片打磨改型
這個(gè)方法改了型號能誤導(dǎo),但同時(shí)也增加成本,解密者一般也能分析出來。
6.通過通過聯(lián)網(wǎng)加序列號加密
通過連接網(wǎng)絡(luò),在你的MCU中生成一個(gè)唯一的隨機(jī)長序列號,并加入復(fù)雜的特種算法,或加入你們重新編碼的企業(yè)信息在里面,每個(gè)芯片內(nèi)不同,復(fù)制者只能復(fù)制到一個(gè)序列號。
7.通過MCU唯一的標(biāo)識加密
以前很多MCU沒有唯一標(biāo)識碼,現(xiàn)在的很多MCU都具有唯一標(biāo)識碼了。
這個(gè)方法比較好,簡單省事,能很好的防止復(fù)制。
二、讀保護(hù) + 唯一ID加密
使用讀保護(hù) + 唯一ID的加密是最常用的一種方法,也是推薦大家使用的一種方法。
1.唯一ID現(xiàn)在正規(guī)的芯片,每顆出廠的時(shí)候都帶了一個(gè)唯一標(biāo)識碼,這個(gè)號碼是唯一不重復(fù)的,比如STM32的就使用96位作為唯一ID。
和我們每個(gè)人的身份證號碼一樣,現(xiàn)在剛出生的嬰兒,上戶的時(shí)候就給他一個(gè)身份證號,那么每個(gè)芯片一生產(chǎn)出來,也就具備了這個(gè)身份證號。
2.加密原理讀保護(hù)就不用說了,增加被破解難度。
使用唯一ID加密的方法很多,這里說一種簡單的方法:出廠時(shí)程序讀取唯一ID并保存在一個(gè)位置,以后程序執(zhí)行之前,要讀取并匹配這個(gè)唯一ID,一致才執(zhí)行程序。當(dāng)然,這種方法是最基礎(chǔ)的原理,但也存在被破解的風(fēng)險(xiǎn)。所以,存儲的數(shù)據(jù),以及讀取驗(yàn)證這兩個(gè)地方需要進(jìn)一步添加一些算法。
這樣操作之后,即使別人讀取了你的程序,也是無法正常執(zhí)行。
-END-
推薦閱讀
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!