利用id做软件加密
1,如果板子上有外部存储器,可以先编写一个程序,利用算法把id计算得到一些值存入外部存储器,然后再烧写真正的程序,真正的程序去校验外部存储器的数据是否合法即可

2,利用板子上按键组合,或是上电按住某些键,程序在这个时候利用算法把id计算得到一些值存入程序区,程序运行时去验证程序区数据是否正确

3,轩微编程器有软件加密的功能,编程器会读芯片id,根据算法直接改写缓冲区,达到软件加密的作用

4,读出的id通过一定算法,例如异或加上一个数,得到的数据存入flash(只运行一次,运行后标志位也存入flash),下次读到这个标志位,就不运行这个程序。

#define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x9ff0)
#define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x9ff4)
void Stm8s103EncryptDemo(void)
{
uint32 *u16IdAddress;
uint16 u32EorRslt, u16AddRslt;

    //千万别显式的读取ID,即要把0x4865运算成隐式的,例如此例中0x4865 = (0x1194 * 4) + 0x215;//这样,别人就算破解出了你的程序,也查找不到0x4865,这样就不能轻易的软解密,这样处理后如果要软解密,//一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。gU16IdAdressVar = 0x1194;gU16IdAdressVar <<= 2;u16IdAddress = (uint16*)(gU16IdAdressVar + 0x215);//0x4865//读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算u16EorRslt = (*u16IdAddress) ^ (*(u16IdAddress + 1)) ^ (*(u16IdAddress + 2));u16AddRslt = (*u16IdAddress) + (*(u16IdAddress + 1)) + (*(u16IdAddress + 2));//进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码if(u16EorRslt != *((uint16*)ID_ENCRYPT_EOR_RESULT_ADDRESS)){while(1);//异或算法结果不正确,进行错误分支}if(u16AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS)){while(1);//和算法结果不正确,进行错误分支}

}

stm8单片机程序加密方法 id加密技巧相关推荐

  1. Windows 7 64位用STC ISP下载51单片机程序的方法

    Windows 7 64位用STC ISP下载51单片机程序的方法2011-09-08 14:17 1  首先在宏晶的主页 http://www.stcmcu.com/ 下载最新的 STC-ISP.E ...

  2. stc51单片机怎么学, 先掌握STC单片机程序烧录方法

    大家好,我是无际的搭档徐明. 今天我在这里和大家探讨一下关于51单片机怎么学这个话题. 08年我在大学里学习单片机课程的时候,学习内容主要包括单片机的发展历史,单片机的框架,单片机的寄存器,以及单片机 ...

  3. STM32程序简单的ID加密

    每一块芯片都有其独一无二的ID,并且ID存储在芯片内部. 我们的代码可以通过读取芯片的ID和我们事先设定的ID值进行比较 如果匹配上了才正常运行代码,从而起到加密效果,防止他人复制程序. STM32F ...

  4. mysql常用加密方法_MYSQL 加密的 3 类方法

    背景: 若你想要储存一些由可能包含任意字节值的加密函数返回的结果,使用BLOB列而不是 CHAR 或VARCHAR 列,从而避免由于结尾空格的删除而改变一些数据值的潜在问题. 这一句话来自官方文件,记 ...

  5. 计算机硬盘加密的几种方法,对于移动硬盘加密方法 你了解多少种呢?

    原标题:对于移动硬盘加密方法 你了解多少种呢? 移动硬盘自然随身携带,有时会丢失.一旦丢失,内部数据将不再安全.如果内部有重要信息,将严重威胁您的信息安全.那么,什么是移动硬盘加密方法?让我们来看看. ...

  6. aes解密流程图_基于AES和混沌的图像加密方法与流程

    本发明涉及一种信息加密技术,特别是涉及一种图像加密方法. 背景技术: 在军事系统.电子政务.金融系统以及日常生活等领域,每天都会产生大量的图像.为保护这些图像信息内容不被窃取,图像加密技术引起了学术界 ...

  7. api接口加密_接口加密如何测试?

    摘要算法: 对明文编码生成信息摘要,以防止被篡改.比如MD5使用的是Hash算法,无论多长的输入,MD5都会输出长度为128bits的一个串. 摘要算法不要秘钥,客户端和服务端采用相同的摘要算法即可针 ...

  8. keil用c语言怎么编辑器,用keil软件编写单片机程序的步骤

    猜你感兴趣: 新手教程:单片机的学习实践步骤 运用单片机便是了解单片机硬件结构,以及内部资源的运用,在汇编或C语言中学会各种功用的初始化设置,以及完成各种功用的程序编制. 运用按钮输入信号,发光二极管 ...

  9. 对称加密和非对称加密!

    主要是对称加密和非对称加密两种.可供各位参考: using System; using System.Collections.Generic; using System.Linq; using Sys ...

  10. python 加密库_Python加密库入门

    python 加密库 密码学俱乐部的第一条规则是:永远不要自己发明密码系统. 密码学俱乐部的第二条规则是:永远不要自己实施密码系统:在密码系统的实施阶段以及设计中都会发现许多现实世界的漏洞. 一个有用 ...

最新文章

  1. 链表python笔试题目_python经典面试算法题1.4:如何对链表进行重新排序
  2. Android Studio打包和引用aar
  3. var lib mysql ib_MYSQL问题解决
  4. 作者:黎建辉(1973-),男,博士,中国科学院计算机网络信息中心研究员、博士生导师。...
  5. mysql数据库连接数瓶颈_MySQL数据库性能优化之硬件瓶颈分析
  6. VirtualBox中的WIN7开启Aero模式要谨慎
  7. ubuntu系统安装百度云盘
  8. 两个摄像头合成一路_一个摄像机怎么添加到两台录像机?
  9. 电气元件知识大全:实物图、作用、型号分类、工作原理、符号都有
  10. 通信线路工程验收规范_老杨一建通信学堂通信线路工程施工技术
  11. Thinkpad E430c安装Ubuntu14.04第三方驱动的选择
  12. 微型计算机外部设备接口,第五章 微型计算机输入输出接口
  13. k8s之亲和性、反亲和性
  14. MySql格式化小数保留小数点后两位
  15. gt; 和 lt; 代表大于号gt; 和小于号lt; 以及其英文的全称
  16. 快讯 | Elon Musk拟跨界做喜剧,号称要建立跨星系传媒帝国Thud!(轰!)
  17. 微信小程序 - 引入并使用 Fly.js 请求库(超级详细的教程及运行示例)提供 Fly.js 源码源文件下载,贴心的配置示例及注释,优雅快速的发起 http 网络请求
  18. c语言程序2000行代码,C语言教务管理系统2000行代码
  19. SpringBoot数据库访问异常HikariPool-1 - Exception during pool initialization.
  20. oracle 增加一个新分区,oracle增加分区的方法

热门文章

  1. BS7799标准全面解析(新版)
  2. linux第八周实验
  3. 有Web认证情况下的路由器设置
  4. 奇迹服务端架设教程技术分享探究——学习
  5. 美著名电话飞客去世 可凭口哨打免费电话(图)
  6. 国内外流行的JS游戏开发框架介绍---kalrry
  7. 怎么把python程序安装到别人电脑上_如何在自己的电脑上安装python的idle版 - 卡饭网...
  8. 云队友丨巴菲特是怎样炼成的?两万字长文深度起底股神的传奇人生
  9. CSDN博客添加使用百度统计
  10. 继电保护计算机化,浅谈继电保护的未来发展趋势