为了防止大家的程序不被剽窃,本文给大家分享单片机加密的方法。 . {4 `9 R* ~; ~: }4 `8 o& K) G. c- Z 常见加密方法 程序写保护 这种方法是最常见,也是最简单的一种。现在的MCU基本都有写保护功能,但是这种容易被人破解。 烧断数据总线 这个方法听起来不错,但有损坏的风险,同样也能破解。 8 _7 p7 w$ e8 C6 L& K* G1 C 软件加密 是一些防止别人读懂程序的方法,单一的这种方法不能防止别人全盘复制,须配合其他的加密算法。 添加外部硬件电路的加密方法 这个方法效果看起来比较好,但会增加成本。 0 M/ o! F" ^* j3 L# c4 @. _ 芯片打磨改型. d) E# K- ^$ { 这个方法改了型号能误导,但同时也增加成本,解密者一般也能分析出来。 通过通过联网加序列号加密 通过连接网络,在你的MCU中生成一个唯一的随机长序列号,并加入复杂的特种算法,或加入你们重新编码的企业信息在里面,每个芯片内不同,复制者只能复制到一个序列号。 5 g: u, e" ?! }6 G, B 通过MCU唯一的标识加密, @% K9 G# m' ~, e 以前很多MCU没有唯一标识码,现在的很多MCU都具有唯一标识码了。 这个方法比较好,简单省事,能很好的防止复制。 8 d) s, c3 O! Y- T 读保护 + 唯一ID加密 使用读保护 + 唯一ID的加密是最常用的一种方法,也是推荐大家使用的一种方法。 + X/ l8 g/ P0 } G* q# W/ Q5 y 唯一ID现在正规的芯片,每颗出厂的时候都带了一个唯一标识码,这个号码是唯一不重复的,比如STM32的就使用96位作为唯一ID。 和我们每个人的身份证号码一样,现在刚出生的婴儿,上户的时候就给他一个身份证号,那么每个芯片一生产出来,也就具备了这个身份证号。 加密原理 读保护就不用说了,增加被破解难度。 使用唯一ID加密的方法很多,这里说一种简单的方法:出厂时程序读取唯一ID并保存在一个位置,以后程序执行之前,要读取并匹配这个唯一ID,一致才执行程序。2 F, W" G4 {# K0 g 当然,这种方法是最基础的原理,但也存在被破解的风险。所以,存储的数据,以及读取验证这两个地方需要进一步添加一些算法。 这样操作之后,即使别人读取了你的程序,也是无法正常执行。) C4 J2 x2 S T " X% C, }3 g4 Q1 ~' ~/ X) A 1 t/ f# j4 n1 e5 G5 K' [ , {- J' k# M: x 转载自:EE时间 |
解析 EN 303 645消费类物联网产品网络安全标准ST助你轻松迈过 “安全关”!
【STM32MPU 安全启动】 TF-A BL2 TrustedBoot原理学习
《STM32MPU安全启动》学**结
【NUCLEO-H533RE评测】二、使能TrustZone的情况下进行产品生命周期管理
【NUCLEO-H533RE评测】一、初识H5安全编程Debug Authentication
STM32 TrustZone 开发调试技巧 | 地址安全区及资源安全属性配置
ST87M01 NB-IoT和GNSS模块获得沃达丰认证
意法半导体数字钥匙解决方案