当前位置: 首页 > article >正文

STM32程序的加密与破解以及烧录方法

STM32程序的加密与破解,以及烧录方法。

盗取他人的PCB和烧录文件,可以节省大大开发成本,何乐而不为呢。因此,就滋生了一些协助他人盗版的公司。为了防止被盗版和复制,单片机工程师也是煞费苦心,对硬件和软件均采取了防盗版措施。

1、硬件防盗措施

1)、对重要芯片实施打磨,擦除芯片的型号,重新印制自定义型号。这样,即使盗版者获取了PCB板,也无法采购生产。

2)、对元件实施灌胶,增加拆卸的难度。

3)、增加高频电感和电容多用分立元件伪装成高频电路,利用盗版者恐惧高频的心理,使其望而却步。

4)、故意用焊锡将某些引脚短接,伪装成生产问题,误导盗版者。

5)、结构防拆功能。市面上的电器插座,电器厂家为了防止维修,故意使用特制的螺丝,也是一种保护措施。

6)、使用多层板设计,采用盲孔和埋孔,增加其复制难度和复制成本。

7)、使用磁耦合电路,比如互感器之类的,利用盗版者不熟悉磁元件,也可以使他们放弃盗窃之动机。

8)、采用多种电源供电,尤其是分立元件的开关电源,也会让盗版者犯难。

盗取硬件的目的,通常是为了盗取原理图,分析其原理,但也有的是为了直接生产。硬件防盗措施,具有局限性,应采用软硬件相结合的方式,让盗版者无从下手。

2、软件防盗措施

1)、借助第3方工具加密。比如:CPU带有读保护功能,可以使用烧录器为烧录的程序设置读保护,防止烧录代码被读取。

2)、利用CPU的唯一ID进行软件加密。这种加密需要注意,不要在FLASH中出现该CPU的ID值,其次不要在FLASH中出现ID寄存器的地址。那么如何可以做到呢?读ID时,通过计算方式,得到ID寄存器的地址,让盗窃者,找不到加密的位置。其次,将读到的ID,通过算法保存到CPU的FLASH中,或是外部其它地方。主要是让盗窃者找不到,或者即使看到了,也不认识是什么东西,就行了。这一切都是在RAM中计算完成的,盗窃者很难看到RAM中的内容,所以就很难盗取代码了。

3)、让程序带系统运行,增加其跟踪的难度。很多盗窃者获取到HEX文件后,采用反汇编工具得到其汇编代码,通过debug办法,跟踪到加密位置,然后修改判断,跳过加密位置,就可以盗取生产代码了。如果程序带有系统,就不好定位加密位置了。

4)、巧用STM32自带的读保护函数FLASH_ReadOutProtection()。大多数软件工程师都会使用这个函数,增加代码的可保护性。启用CPU的读保护功能后,盗窃者无法获取源代码,就无法进行反汇编了。

5)、编写升级软件,防止生产者泄密。升级软件是用来对客户的程序进行升级更新。它可以绕过自己的读保护程序,对设备程序进行升级或更新,特别是在远程更新中,有利于防止代码泄密。没有升级软件的代码,要想实现读保护,只能靠烧录器添加读保护,但不能保证烧录程序的人不泄密。升级软件则不同,烧写程序的人,必须使用升级软件才能更新程序。即使他有了客户程序,离开升级软件的引导,程序没法工作。即使他能写升级程序,但是不知道程序的定位位置,也是无法启动客户程序。如果此时再增加唯一ID加密,就会更难破解。

第1次接触STM32,发现它有很多种烧录方式,觉得很奇怪。比如:JTAG接口烧录,SWD接口烧录,串口烧录等,还有就是可以自己编写Boot loader升级程序。现在看来,真是太好了。其实,这些方法都是为生产服务的。

总结,堡垒很容易从内部攻破,再好的盾牌,也难以防盗。

如何使用自己的Boot loader升级程序 呢?

最常用的办法,就是通过串口通讯。一个是上位机,它负责读取CPU内部的客户程序,通过串口发送给下位机。这个下位机带有Boot loader升级程序 ,它是由烧录器烧录的。上电后会判断是否烧录了客户程序,若没有,就会通过串口接收上位机的烧录数据,写到CPU的FLASH中。若已经烧录过客户程序,就会自动跳转到客户程序执行。上位机的客户程序是由烧录器按照指定的位置,烧录到CPU的FALSH中。上位机上电后,就会根据定义好握手协议,将烧录的客户程序发送给下位机。这种烧写方法,是一个创新。网上大多数是采用专用的串口软件来读取bin文件,实现起来有点难。我们不是全才,写个单片机程序,我们很拿手,烧录我们也会,为何不写Boot loader升级程序 和串口通讯来实现烧录呢,而且,还可以实现加密,何乐而不为呢。

由于涉及到保密,不能一一举例讲解实现和破解,只能写写方法,与大家交流。

相关文章:

STM32程序的加密与破解以及烧录方法

STM32程序的加密与破解,以及烧录方法。 盗取他人的PCB和烧录文件,可以节省大大开发成本,何乐而不为呢。因此,就滋生了一些协助他人盗版的公司。为了防止被盗版和复制,单片机工程师也是煞费苦心,对硬件和软…...

Redis和MySQL的实时数据同步方案

针对 Redis 和 MySQL 的实时数据同步,需根据业务场景选择不同的技术方案,核心目标是保障数据一致性、降低延迟、提升系统可靠性。以下是几种典型方案及其适用场景: 方案一:基于 MySQL Binlog 的异步同步 原理 监听 MySQL 的 Bin…...

VSCode知名主题带毒 安装量900万次

目前微软已经从 Visual Studio Marketplace 中删除非常流行的主题扩展 Material Theme Free 和 Material Theme Icons,微软称这些主题扩展包含恶意代码。 统计显示这些扩展程序的安装总次数近 900 万次,在微软实施删除后现在已安装这些扩展的开发者也会…...

JavaScript 进阶A(作用域、闭包、变量和函数提升、函数相关只是、数组解构、对象解构、构造函数

1.作用域 作用域主要分为:局部作用域和全局作用域。 局部作用域又分为:函数作用域和块作用域 函数作用域:在函数中定义的变量只能在函数内部使用,外部无法访问块作用域:被大括号{}包起来的代码块,在这个…...

mybatis映射文件相关的知识点总结

mybatis映射文件相关的知识点总结 mybatis官网地址 英文版:https://mybatis.org/mybatis-3/index.html 中文版:https://mybatis.p2hp.com/ 搭建环境 /* SQLyog Ultimate v10.00 Beta1 MySQL - 8.0.30 : Database - mybatis-label *****************…...

【UCB CS 61B SP24】Lecture 21: Data Structures 5: Priority Queues and Heaps 学习笔记

本文介绍了优先队列与堆,分析了最小堆的插入与删除过程,并用 Java 实现了一个通用类型的最小堆。 1. 优先队列 1.1 介绍 优先队列是一种抽象数据类型,其元素按照优先级顺序被处理。不同于普通队列的先进先出(FIFO)&…...

【JAVA】ThreadPoolTaskExecutor 线程池学习、后端异步、高并发处理

ThreadPoolTaskExecutor 是 Spring 框架提供的一个线程池实现类,基于 Java 原生的 ThreadPoolExecutor 进行了封装和扩展,支持更灵活的配置,并与 Spring 的依赖注入、生命周期管理等功能无缝集成。它常用于异步任务处理、定时任务调度和高并发…...

C#:LINQ学习笔记01:LINQ基础概念

一、LINQ 架构体系 1. LINQ 的核心思想 统一查询模型:对对象、XML、数据库等不同数据源使用一致的语法。强类型检查:编译时类型安全,减少运行时错误。 2. 核心组件 技术数据源典型场景LINQ to Objects内存集合 (IEnumerable)过滤/排序集合…...

爬虫系列之发送请求与响应《一》

一、请求组成 1.1 请求方式:GET和POST请求 GET:从服务器获取,请求参数直接附在URL之后,便于查看和分享,常用于获取数据和查询操作 POST:用于向服务器提交数据,其参数不会显示在URL中,而是包含在…...

【零基础到精通Java合集】第十集:List集合框架

课程标题:List集合框架(15分钟) 目标:掌握List接口核心实现类(ArrayList/LinkedList)的使用与场景选择,熟练操作有序集合 0-1分钟:List概念引入 以“购物清单”类比List特性:元素有序(添加顺序)、可重复、支持索引访问。说明List是Java集合框架中最常用的数据结构…...

小米手机如何录制屏幕?手机、电脑屏幕录制方法分享

大家最近有没有遇到想记录手机屏幕操作的情况? 比如精彩的游戏瞬间、有趣的视频教程,或者需要录制屏幕来制作演示材料。小米手机在这方面可是个好帮手,今天就来给你好好唠唠,小米手机如何录制屏幕,以及后续如何处理这…...

【RTC】 TM32 RTC(实时时钟)库函数 配置

1. 硬件配置 与HAL库相同,需确保以下硬件条件: 外部低速晶振(LSE,32.768kHz)连接至 OSC32_IN 和 OSC32_OUT 引脚。 备用电池(VBAT)已连接,确保断电时RTC持续运行。 2. 标准外设库(库函数)配置步骤 2.1 初始化RTC时钟源 #include "stm32f10x.h" #include…...

策略模式的C++实现示例

核心思想 策略模式是一种行为型设计模式,它定义了一系列算法,并将每个算法封装在独立的类中,使得它们可以互相替换。策略模式让算法的变化独立于使用它的客户端,从而使得客户端可以根据需要动态切换算法,而不需要修改…...

deepseek、腾讯元宝deepseek R1、百度deepseekR1关系

分析与结论 区别与联系 技术基础与定制方向: DeepSeek官网R1版本:作为基础版本,通常保留通用性设计,适用于广泛的AI应用场景(如自然语言处理、数据分析等)。其优势在于技术原生性和官方直接支持。腾讯元宝…...

Leetcode 面试150题(三)

一、题目 给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 考虑 nums 的唯一元素的数量为 k &am…...

3D Web轻量化引擎HOOPS Communicator的核心优势解析:高性能可视化与灵活部署!

在当今数字化时代,工业领域的工程应用不断向基于Web的方向发展,而HOOPS Web平台作为一款专为构建此类工程应用程序打造的软件开发套件集,正发挥着日益重要的作用,成为构建强大工程应用的基石。 一、HOOPS Web平台概述 HOOPS Web…...

python爬虫:python中使用多进程、多线程和协程对比和采集实践

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 1. 多进程爬虫1.1 python多进程样例1.2 实现多进程爬虫2. 多线程爬虫2.1 python多线程样例2.2 实现多线程爬虫3. 协程爬虫3.1 python协程样例3.2 实现协程爬虫在网络爬虫中,为了提高抓取效率,常常需要使用多进程、多线…...

从 JVM 源码(HotSpot)看 synchronized 原理

大家好,我是此林。 不知道大家有没有这样一种感觉,网上对于一些 Java 框架和类的原理实现众说纷纭,看了总是不明白、不透彻。常常会想:真的是这样吗? 今天我们就从 HotSpot 源码级别去看 synchronized 的实现原理。全…...

深入探索Python机器学习算法:模型调优

深入探索Python机器学习算法:模型调优 文章目录 深入探索Python机器学习算法:模型调优模型调优1. 超参数搜索方法1.1 网格搜索(Grid Search)1.2 随机搜索(Random Search)1.3 贝叶斯优化(Bayesia…...

windows 上删除 node_modules

在 Windows 11 上,你可以通过命令行来删除 node_modules 文件夹并清除 npm 缓存。以下是具体步骤: 删除 node_modules 打开命令提示符(Command Prompt)或终端(PowerShell)。 导航到项目目录。你可以使用 …...

postman请求后端接受List集合对象

后端集合 post请求,即前端请求方式...

Kimi“撞车”DeepSeek!新一代注意力机制的极限突破!

近期,各方大佬在注意力机制上又“打起来了”。首先登场的是顶流DeepSeek,新论文梁文锋署名,提出了一种新的注意力机制NSA。同天,Kimi杨植麟署名的新注意力架构MoBA开源。紧接着,华为诺亚提出高效选择注意力架构ESA。 …...

如何在Android中实现服务(Service)

在Android中,Service 是一种用于在后台执行长时间运行操作而不提供用户界面的组件。Service 可以执行各种后台任务,如下载文件、播放音乐、执行定时任务等。以下是如何在Android中实现Service的基本步骤: 1. 创建一个Service类 首先&#x…...

计算机网络---SYN Blood(洪泛攻击)

文章目录 三次握手过程SYN Flood攻击原理防御措施协议层优化网络层拦截系统配置调整 TCP协议是 TCP/IP 协议栈中一个重要的协议,平时我们使用的浏览器,APP等大多使用 TCP 协议通讯的,可见 TCP 协议在网络中扮演的角色是多么的重要。 TCP 协议…...

Ollama存在安全风险的情况通报及解决方案

据清华大学网络空间测绘联合研究中心分析,开源跨平台大模型工具Ollama默认配置存在未授权访问与模型窃取等安全隐患。鉴于目前DeepSeek等大模型的研究部署和应用非常广泛,多数用户使用Ollama私有化部署且未修改默认配置,存在数据泄露、算力盗…...

视频流畅播放相关因素

视频播放的流畅度是一个综合性问题,涉及从视频文件本身到硬件性能、网络环境、软件优化等多个环节。以下是影响流畅度的关键因素及优化建议: 一、视频文件本身 1. 分辨率与帧率 1.问题:高分辨率(如4K)或高帧率&#…...

蓝桥杯试题:二分查找

一、问题描述 给定 n 个数形成的一个序列 a,现定义如果一个连续子序列包含序列 a 中所有不同元素,则该连续子序列便为蓝桥序列,现在问你,该蓝桥序列长度最短为多少? 例如 1 2 2 2 3 2 2 1,包含 3 个不同的…...

机器人训练环境isaac gym以及legged_gym项目的配置问题

完整的安装环境教程(强烈推荐):...

Qt QOCI driver available but not loaded(可用但未加载)

参考Linux Qt 6安装Oracle QOCI SQL Driver插件(适用WSL),根据SQL Database Drivers成功将libqsqloci.so、qsqloci.debug等文件安装到/opt/Qt6.8.2/6.8.2/gcc_64/plugins/sqldrivers后,运行Qt程序并尝试连接数据库时仍然报错 QSql…...

健康医疗大数据——医疗影像

一、 项目概述 1.1 项目概述 1.2 项目框架 1.3 项目环境 1.4 项目需求 二、项目调试与运行 2.1需求分析 2.2具体实现 三、项目总结 项目概述 项目概述 本项目旨在应用大数据技术于医疗影像领域,通过实训培养团队成员对医疗大数据处理和分析的实际…...