关于stm32程序加密的想法
2022/1/15 20:05:29
本文主要是介绍关于stm32程序加密的想法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
stm32的加密有很多方法,利用ID号码加密,读保护加密,这些方法都是最常见的方法,也容易被破解。
我在想,能不能利用PCB硬件参数的差异,通过校准保存参数,然后让程序严格按照保存的参数去运行,当然要考虑环境(例如温度)对参数的影响,加一些补偿算法。
如果没有校准过程,硬件参数偏差大的板子运算精准度很差,甚至运行异常。
由于硬件有差异,每块板子校准出来的参数都有偏差,这样即使别人拷贝出Hex文件,放到他们的板子上也不一定正常工作,量产不良率高。
当然,对方也可以推测校准参数的意义和范围,通过修正校准参数,维修不良的板子。
但是也不容易,首先要知道我保存的参数的含义,例如,参数A跟电压采样值有关,参数B和电流采样值有关,参数C和NTC温度有关,参数D和功率系数有关等等,即使猜到了,还要知道修正多少才合理,要么一个一个数值去试,要么测量出硬件参数计算后再修正。
我们还可以在参数列表中插入成百上千个随机数,让随机数和参数填满空白的Flash,不让对方那么容易找出这些参数。
还有更狠的方法,即使参数偏差大(我知道校准参数偏差的范围,有校准的板子不可能这么大的),也让板子工作(只是输出的电压和电流精准度差,勉强能用),程序会累积工作时长并保存,超出时长后锁机。对方没有长时间测试的话是测不到问题的,认为破解成功了就去量产,量产后到客户手上使用一段时间(控制在质保期内)再出问题。
但建议不用这种方法,其一,可能让对手损失惨重,其二,如果你的产品是应急设备,锁机可能耽误救人。
当然,以上方法没有经过实际验证,不知道是否可行,还请同学们给些意见。
这篇关于关于stm32程序加密的想法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-19《2023版Java工程师》课程升级公告
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)
- 2024-05-31全网首发!软考2024年5月《软件设计师》真题+解析+答案!(21-30题)
- 2024-05-30【Java】百万数据excel导出功能如何实现