meijc119

  • 2019-11-08
  • 回复了主题帖: 如何使用uniquedeviceid进行加密(防拷贝)

    利用id做软件加密 1,如果板子上有外部存储器,可以先编写一个程序,利用算法把id计算得到一些值存入外部存储器,然后再烧写真正的程序,真正的程序去校验外部存储器的数据是否合法即可   2,利用板子上按键组合,或是上电按住某些键,程序在这个时候利用算法把id计算得到一些值存入程序区(stm8为EE区),程序运行时去验证程序区数据是否正确   3,轩微编程器有软件加密的功能,编程器会读芯片id,根据算法直接改写缓冲区,达到软件加密的作用   4,读出的id通过一定算法,例如异或加上一个数,得到的数据存入flash(只运行一次,运行后标志位也存入flash),下次读到这个标志位,就不运行这个程序。   四、做软件加密时注意 1,不要在程序中直接出现id地址,例如STM32:1FFFF7E8 1FFFF7EC 1FFFF7F0   STM8: 0x4865~0x4870 2, 利用校验和或是crc对程序区进行校验,防止改程序

  • 回复了主题帖: 使用STVP对STM8进行加密和解除写保护

    利用id做软件加密 1,如果板子上有外部存储器,可以先编写一个程序,利用算法把id计算得到一些值存入外部存储器,然后再烧写真正的程序,真正的程序去校验外部存储器的数据是否合法即可   2,利用板子上按键组合,或是上电按住某些键,程序在这个时候利用算法把id计算得到一些值存入程序区,程序运行时去验证程序区数据是否正确   3,轩微编程器有软件加密的功能,编程器会读芯片id,根据算法直接改写缓冲区,达到软件加密的作用   4,读出的id通过一定算法,例如异或加上一个数,得到的数据存入flash(只运行一次,运行后标志位也存入flash),下次读到这个标志位,就不运行这个程序。//QQ9272078   四、做软件加密时注意 1,不要在程序中直接出现id地址,stm32例如1FFFF7E8 1FFFF7EC 1FFFF7F0 stm8:0x4865~0x4870        2, 利用校验和或是crc对程序区进行校验,防止改程序

  • 2019-10-28
  • 回复了主题帖: STM32的唯一ID---加密方式升级

    这样做还是可以破解的,程序加一些校验,如果发现有改动判断为非法,QQ5225016

  • 2019-09-06
  • 回复了主题帖: 求助怎么保证产品不被破解盗版

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

最近访客

< 1/1 >

统计信息

已有3人来访过

  • 芯币:23
  • 好友:--
  • 主题:--
  • 回复:5
  • 课时:--
  • 资源:--

留言

你需要登录后才可以留言 登录 | 注册


现在还没有留言