OpenVINOTM,给你看得见的未来!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » STM32 » 基于芯片唯一ID的软加密方法及实例代码

共8条 1/1 1 跳转至

基于芯片唯一ID的软加密方法及实例代码

工程师
2019-11-07 16:49:31    评分

/STM32F10X软加密方法及实例代码

#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);//和算法结果不正确,进行错误分支
        }
}




关键词: 加密     ID     破解     STM32    

助工
2019-11-07 22:06:21    评分
2楼

这个很实用啊 防止代码被抄袭


助工
2019-11-07 23:39:06    评分
3楼

受教了!

读id---》复杂算法计算---》对比之前存储的对应数据(与id相关)---》判断芯片是否合法。


助工
2019-11-07 23:42:25    评分
4楼

如果是我,我读到二进制码后,直接跳转避开以下,我觉得该“加密”就无效了吧?!


  if(u32EorRslt != *((uint32*)ID_ENCRYPT_EOR_RESULT_ADDRESS))
        {
                while(1);//异或算法结果不正确,进行错误分支
        }
        if(u32AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS))
        {
                while(1);//和算法结果不正确,进行错误分支
        }


助工
2019-11-08 00:14:04    评分
5楼

先MARK收藏,有时间再研究研究。。。


专家
2019-11-09 22:33:15    评分
6楼

这个方法靠谱不?

我们批量购买的芯片时,人家怎么说这个唯一ID慎重使用啊


工程师
2019-11-11 22:26:01    评分
7楼

分享的代码很不错


助工
2019-11-16 22:44:58    评分
8楼

很有用的代码


共8条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]