| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> 关于stm32程序加密的想法 -> 正文阅读 |
|
[嵌入式]关于stm32程序加密的想法 |
stm32的加密有很多方法,利用ID号码加密,读保护加密,这些方法都是最常见的方法,也容易被破解。 我在想,能不能利用PCB硬件参数的差异,通过校准保存参数,然后让程序严格按照保存的参数去运行,当然要考虑环境(例如温度)对参数的影响,加一些补偿算法。 如果没有校准过程,硬件参数偏差大的板子运算精准度很差,甚至运行异常。 由于硬件有差异,每块板子校准出来的参数都有偏差,这样即使别人拷贝出Hex文件,放到他们的板子上也不一定正常工作,量产不良率高。 当然,对方也可以推测校准参数的意义和范围,通过修正校准参数,维修不良的板子。 但是也不容易,首先要知道我保存的参数的含义,例如,参数A跟电压采样值有关,参数B和电流采样值有关,参数C和NTC温度有关,参数D和功率系数有关等等,即使猜到了,还要知道修正多少才合理,要么一个一个数值去试,要么测量出硬件参数计算后再修正。 我们还可以在参数列表中插入成百上千个随机数,让随机数和参数填满空白的Flash,不让对方那么容易找出这些参数。 还有更狠的方法,即使参数偏差大(我知道校准参数偏差的范围,有校准的板子不可能这么大的),也让板子工作(只是输出的电压和电流精准度差,勉强能用),程序会累积工作时长并保存,超出时长后锁机。对方没有长时间测试的话是测不到问题的,认为破解成功了就去量产,量产后到客户手上使用一段时间(控制在质保期内)再出问题。 但建议不用这种方法,其一,可能让对手损失惨重,其二,如果你的产品是应急设备,锁机可能耽误救人。 当然,以上方法没有经过实际验证,不知道是否可行,还请同学们给些意见。 |
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/9 1:24:05- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |