- #define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x0800F000)
- #define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x0800F004)
- volatile uint32 gU32IdAdressVar;//这里一定要定义此变量,否则会被优化器优化掉
- void Stm32F10xEncryptDemo(void)
- {
- uint32 *u32IdAddress;
- uint32 u32EorRslt, u32AddRslt;
- #IF 0
- //如果直接赋值0X1FFFF7E8,则程序编译结果里会有0X1FFFF7E8,这样破解人员会很轻松
- //的找到这个内容,然后非常容易进行修改,去掉软加密
- u32IdAddress = (uint32*)0x1ffff7e8;
- #else
- //千万别显式的读取ID,即要把0X1FFFF7E8运算成隐式的,例如此例中0x1FFFF7E8 = (0x455873a * 4) + 0xEA9DB00;
- //这样,别人就算破解出了你的程序,也查找不到0X1FFFF7E8,这样就不能轻易的软解密,这样处理后如果要软解密,
- //一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。
- gU32IdAdressVar = 0x455873a;
- gU32IdAdressVar <<= 2;//0x11561CE8
- u32IdAddress = (uint32*)(gU32IdAdressVar + 0xEA9DB00);//0x1ffff7e8
- #endif
- //读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算
- u32EorRslt = (*u32IdAddress) ^ (*(u32IdAddress + 1)) ^ (*(u32IdAddress + 2));
- u32AddRslt = (*u32IdAddress) + (*(u32IdAddress + 1)) + (*(u32IdAddress + 2));
- //进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码
- if(u32EorRslt != *((uint32*)ID_ENCRYPT_EOR_RESULT_ADDRESS))
- {
- while(1);//异或算法结果不正确,进行错误分支
- }
- if(u32AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS))
- {
- while(1);//和算法结果不正确,进行错误分支
- }
- }
复制代码
【必读】版权免责声明
1、本主题所有言论和内容纯属会员个人意见,与本论坛立场无关。2、本站对所发内容真实性、客观性、可用性不做任何保证也不负任何责任,网友之间仅出于学习目的进行交流。3、对提供的数字内容不拥有任何权利,其版权归原著者拥有。请勿将该数字内容进行商业交易、转载等行为,该内容只为学习所提供,使用后发生的一切问题与本站无关。 4、本网站不保证本站提供的下载资源的准确性、安全性和完整性;同时本网站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。 5、本网站所有软件和资料均为网友推荐收集整理而来,仅供学习用途使用,请务必下载后两小时内删除,禁止商用。6、如有侵犯你版权的,请及时联系我们(电子邮箱1370723259@qq.com)指出,本站将立即改正。
|