你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32等单片机程序加密的方法

[复制链接]
STMCU小助手 发布时间:2021-7-27 10:49
  为了防止大家的程序不被剽窃,本文给大家分享单片机加密的方法。
9 S# L9 ^- D5 N0 P( U 11.jpg
$ L/ Y5 a- a6 J7 ^+ u3 D1 C
9 u3 b+ a/ k7 Z0 ~2 b" K

# o2 F; u9 N. D3 A: p常见加密方法, z4 x$ s4 V# V6 b" G  r
1. 程序写保护
7 I! n7 S( A6 o. q, Z% ^    这种方法是最常见,也是最简单的一种。现在的MUC基本都有写保护功能,但是这种容易被人破解。! j3 K* t: n/ }, b/ H: p3 s6 n
8 O4 a5 x, z* Y
2. 烧断数据总线
7 g! \, p3 _4 f$ o    这个方法听起来不错,但有损坏的风险,同样也能破解。
# z( }4 W, T0 C0 i9 g- a( s% D. [" K8 p9 R; u$ c$ f

6 a  T0 F/ l3 a: L) |7 {3. 软件加密1 S' |2 e* P: [/ v" F2 i
    是一些防止别人读懂程序的方法,单一的这种方法不能防止别人全盘复制,须配合其他的加密算法。3 j# ^( ^' `4 ]4 K! j- \: a
# l5 S. ?3 V* X( h: \" @; a. u/ r
( A* t! ?, g  d5 L9 G/ |
4. 添加外部硬件电路的加密方法9 x; a" z( L5 ~1 m3 o/ K+ h
    这个方法效果看起来比较好,但会增加成本。
' K* n' R) J' m" Z% {0 X6 P2 M3 z# U# c% v( u% N. l% B9 I4 j
# c' t2 S+ y, }7 E' @" ?  o
5. 芯片打磨改型
7 e# v# y5 @9 }. k; u    这个方法改了型号能误导,但同时也增加成本,解密者一般也能分析出来。
- h' t& C/ c7 S0 l2 |; W: F& q
6 E' X# t7 X, [* w3 d

$ j/ s- S% N: Y- [; x; ]& I6. 通过通过联网加序列号加密
! z6 T8 l. c7 J( a1 Z7 E* |    通过连接网络,在你的MCU中生成一个唯一的随机长序列号,并加入复杂的特种算法,或加入你们重新编码的企业信息在里面,每个芯片内不同,复制者只能复制到一个序列号。
+ @" Z8 ^" R  H
% M! T9 ^( X8 Y3 j8 E- D
/ K4 ?7 |- l/ L" ?, |
7. 通过MCU唯一的标识加密
9 V* {4 J% B9 c' m    以前很多MCU没有唯一标识码,现在的很多MCU都具有唯一标识码了。& M- g- B; {) l2 d/ H: E7 m$ i
    这个方法比较好,简单省事,能很好的防止复制。/ B/ e/ m$ |) |. C8 I) O3 }
5 `: p) J+ g+ @2 o8 K9 \1 b' f: s
- B8 H/ h( q+ n
8. 读保护 + 唯一ID加密
- u& i& Z7 }, P6 F    使用读保护 + 唯一ID的加密是最常用的一种方法,也是推荐大家使用的一种方法。
7 C5 W3 P% K2 [* l: L
2 W; x; ^; r6 _: [1 Q: Q
, B8 G7 z- Q+ X+ m
9. 唯一ID. v3 G; S% W  Y0 ^
    现在正规的芯片,每颗出厂的时候都带了一个唯一标识码,这个号码是唯一不重复的,比如STM32的就使用96位作为唯一ID。: K( H) K* r5 Q5 H9 l, s
    和我们每个人的身份证号码一样,现在刚出生的婴儿,上户的时候就给他一个身份证号,那么每个芯片一生产出来,也就具备了这个身份证号。
# C' Z5 ?! }, k5 K; t, W1 E
! W, R3 a+ m$ e+ o  _9 n
4 ]( ~% y% V( E' z* ?  `7 ?
加密原理
3 h  J5 Y+ ^6 ]3 Q    读保护就不用说了,增加被破解难度。
1 V- t- }" ^* U! \    使用唯一ID加密的方法很多,这里说一种简单的方法:出厂时程序读取唯一ID并保存在一个位置,以后程序执行之前,要读取并匹配这个唯一ID,一致才执行程序。# `  y; E) B, n: A: r
    当然,这种方法是最基础的原理,但也存在被破解的风险。所以,存储的数据,以及读取验证这两个地方需要进一步添加一些算法。, U3 V2 ?7 [4 z! F
    这样操作之后,即使别人读取了你的程序,也是无法正常执行。
8 E- r7 k+ c' f; B8 i8 d: o
1 r3 X# o2 N) Z) O. S7 O
- M  y0 R, c# o: r) Y4 R
收藏 1 评论0 发布时间:2021-7-27 10:49

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版