0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

STM32等单片机程序加密有哪些方法

STM32嵌入式开发 来源:电子工程世界-论坛 作者:可乐zzZ 2021-09-23 16:06 次阅读

为了防止大家的程序不被剽窃,本文给大家分享单片机加密的方法。

另外关于解密的方法可以参考这篇文章如何解密单片机内程序?

常见加密方法

程序写保护

这种方法是最常见,也是最简单的一种。现在的MUC基本都有写保护功能,但是这种容易被人破解。

烧断数据总线

这个方法听起来不错,但有损坏的风险,同样也能破解。

软件加密

是一些防止别人读懂程序的方法,单一的这种方法不能防止别人全盘复制,须配合其他的加密算法

添加外部硬件电路的加密方法

这个方法效果看起来比较好,但会增加成本。

芯片打磨改型

这个方法改了型号能误导,但同时也增加成本,解密者一般也能分析出来。

通过通过联网加序列号加密

通过连接网络,在你的MCU中生成一个唯一的随机长序列号,并加入复杂的特种算法,或加入你们重新编码的企业信息在里面,每个芯片内不同,复制者只能复制到一个序列号。

通过MCU唯一的标识加密

以前很多MCU没有唯一标识码,现在的很多MCU都具有唯一标识码了。

这个方法比较好,简单省事,能很好的防止复制。

读保护 + 唯一ID加密

使用读保护 + 唯一ID的加密是最常用的一种方法,也是推荐大家使用的一种方法。

唯一ID 现在正规的芯片,每颗出厂的时候都带了一个唯一标识码,这个号码是唯一不重复的,比如STM32的就使用96位作为唯一ID。 和我们每个人的身份证号码一样,现在刚出生的婴儿,上户的时候就给他一个身份证号,那么每个芯片一生产出来,也就具备了这个身份证号。

加密原理 读保护就不用说了,增加被破解难度。 使用唯一ID加密的方法很多,这里说一种简单的方法:出厂时程序读取唯一ID并保存在一个位置,以后程序执行之前,要读取并匹配这个唯一ID,一致才执行程序。 当然,这种方法是最基础的原理,但也存在被破解的风险。

所以,存储的数据,以及读取验证这两个地方需要进一步添加一些算法。 这样操作之后,即使别人读取了你的程序,也是无法正常执行。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    5997

    文章

    43945

    浏览量

    620472
  • mcu
    mcu
    +关注

    关注

    145

    文章

    15984

    浏览量

    343283
  • STM32
    +关注

    关注

    2239

    文章

    10663

    浏览量

    348464

原文标题:STM32等单片机程序加密的方法

文章出处:【微信号:c-stm32,微信公众号:STM32嵌入式开发】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    求助,英飞凌单片机程序开发和STM32程序开发之间多少差异?

    英飞凌单片机程序开发和STM32程序开发之间多少差异?英飞凌单片机有没有类似库函数的东西?
    发表于 02-05 07:14

    STM32程序烧写方法#单片机

    单片机STM32程序
    油泼辣子
    发布于 :2023年12月11日 10:35:07

    stm32和51单片机的区别

    架构,STM32单片机具有更高的运行速度和更好的性能,可以运行更复杂的任务。而51单片机的性能较低,只适合一些简单的任务。 存储 STM32单片机
    发表于 11-20 13:18

    GD32单片机STM32远程下载手机程序升级固件下载局域网网页升级工具

    GD32、STM32单片机,是我们最常见的一种MCU。通常我们在使用STM32单片机都会遇到程序在线升级下载的问题。 GD32/
    发表于 11-10 15:03

    STC的单片机如何加密代码?

    STC的单片机如何加密代码啊
    发表于 10-20 07:23

    STM32单片机IAP程序分享

    STM32单片机IAP程序
    发表于 09-25 06:57

    stm32单片机如何实现一个按键切换两个程序

    stm32单片机如何实现一个按键切换两个程序? 作为一款功能强大的微控制器,STM32单片机可以支持多种应用场景,其中一个实用的功能是按键切
    的头像 发表于 09-14 14:22 4333次阅读

    怎么擦除stm32单片机里面的程序呢?

    怎么擦除stm32单片机里面的程序呢? 要擦除STM32单片机内部的程序,需要以下步骤: 1.
    的头像 发表于 09-14 14:22 8283次阅读

    51单片机烧写程序方法

    STC89C51是应用广泛的51单片机,很多人都是通过该单片机入门学习的,单片机的学习需要勤动手。单片机需要烧写程序,要用到相关的软件和硬件
    的头像 发表于 09-11 10:10 3400次阅读
    51<b class='flag-5'>单片机</b>烧写<b class='flag-5'>程序</b>的<b class='flag-5'>方法</b>

    什么是单片机解密?单片机解密方法有哪些?

    单片机(MCU)一般都有内部程序区和数据区(或者其一)供用户存放程序和工作数据(或者其一)。为了防止未经授访问或拷贝单片机的机内程序,大部分
    发表于 08-28 09:26 477次阅读

    STM32单片机程序编译及下载配置

    当拿到STM32单片机开发板的时候,程序的编译和下载将是我们踏入STM32单片机开发的第一步。本章详细介绍
    发表于 08-11 16:08 3177次阅读
    <b class='flag-5'>STM32</b><b class='flag-5'>单片机</b><b class='flag-5'>程序</b>编译及下载配置

    STM32单片机与外设的通信方式哪些?

    STM32单片机
    YS YYDS
    发布于 :2023年05月15日 22:34:02

    STM32单片机与外设的通信方式哪些?

    STM32单片机
    YS YYDS
    发布于 :2023年05月15日 22:33:23

    单片机解密方法

    单片机(MCU)一般都有内部程序区和数据区(或者其一)供用户存放程序和工作数据(或者其一)。为了防止未经授访问或拷贝单片机的机内程序,大部分
    发表于 04-25 09:30 563次阅读

    基于stm32单片机的智能窗帘仿真设计(包含源程序及仿真)

    基于stm32单片机的智能窗帘仿真设计(包含源程序及仿真)
    发表于 04-20 15:54 8次下载