找回密码
 注册

QQ登录

只需一步,快速开始

搜索

STM32F10X软加密方法及实例代码

[复制链接]
coolice 发表于 2021-8-13 18:15:15 | 显示全部楼层 |阅读模式
  1. #define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x0800F000)
  2. #define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x0800F004)
  3. volatile uint32 gU32IdAdressVar;//这里一定要定义此变量,否则会被优化器优化掉
  4. void Stm32F10xEncryptDemo(void)
  5. {
  6.         uint32 *u32IdAddress;
  7.   uint32 u32EorRslt, u32AddRslt;
  8.         #IF 0
  9.         //如果直接赋值0X1FFFF7E8,则程序编译结果里会有0X1FFFF7E8,这样破解人员会很轻松
  10.         //的找到这个内容,然后非常容易进行修改,去掉软加密
  11.         u32IdAddress = (uint32*)0x1ffff7e8;
  12.         #else
  13.         //千万别显式的读取ID,即要把0X1FFFF7E8运算成隐式的,例如此例中0x1FFFF7E8 = (0x455873a * 4) + 0xEA9DB00;
  14.         //这样,别人就算破解出了你的程序,也查找不到0X1FFFF7E8,这样就不能轻易的软解密,这样处理后如果要软解密,
  15.         //一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。
  16.         gU32IdAdressVar = 0x455873a;
  17.         gU32IdAdressVar <<= 2;//0x11561CE8
  18.         u32IdAddress = (uint32*)(gU32IdAdressVar + 0xEA9DB00);//0x1ffff7e8
  19.         #endif
  20.         //读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算
  21.         u32EorRslt = (*u32IdAddress) ^ (*(u32IdAddress + 1)) ^ (*(u32IdAddress + 2));
  22.         u32AddRslt = (*u32IdAddress) + (*(u32IdAddress + 1)) + (*(u32IdAddress + 2));
  23.         //进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码
  24.         if(u32EorRslt != *((uint32*)ID_ENCRYPT_EOR_RESULT_ADDRESS))
  25.         {
  26.                 while(1);//异或算法结果不正确,进行错误分支
  27.         }
  28.         if(u32AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS))
  29.         {
  30.                 while(1);//和算法结果不正确,进行错误分支
  31.         }
  32. }
复制代码


您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|ELEOK |网站地图

GMT+8, 2025-1-21 09:00

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表