找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

帖子
查看: 2565|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

stm32芯片利用唯一ID對(duì)程序進(jìn)行加密的一種方法

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:346927 發(fā)表于 2021-5-27 15:14 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式

  #define STM32_ID_D  352525   //任意的一個(gè)數(shù)
  //stm32芯片的ID地址,把地址減去一個(gè)數(shù),避免匯編里面直接出現(xiàn)ID的地址,不然很容易暴露加密與ID號(hào)有關(guān)
  volatile u32 STM32_ID_addr[3]={0x1ffff7e8 - STM32_ID_D,0x1ffff7ec + STM32_ID_D,0x1ffff7f0 - STM32_ID_D};
   
  /********************************************************************
  函數(shù)功能:讀出stm32的ID,12字節(jié)
  入口參數(shù):p
  返    回:
  備    注:把ID的地址做一下處理,加密性更好
  ********************************************************************/
  volatile void STM32_Read_ID(volatile u32 *p)
  {
     volatile u32 Addr;
  // 因?yàn)椴幌胱尦绦蛟诜磪R編后直接找到這個(gè)地址,所以這個(gè)地址是運(yùn)算出來(lái)的,
  // 跟STM32_ID_addr反運(yùn)算,當(dāng)然了也可以用高級(jí)的算法,注意不能讓編譯器優(yōu)化這個(gè)地址
     Addr = STM32_ID_addr[0] + STM32_ID_D;
     p[0] = *(vu32*)(Addr);
     Addr = STM32_ID_addr[1] - STM32_ID_D;
     p[1] = *(vu32*)(Addr);
     Addr = STM32_ID_addr[2] + STM32_ID_D;
     p[2] = *(vu32*)(Addr);
  }
  /********************************************************************
  函數(shù)功能:加密ID并保存
  入口參數(shù):
  返    回:
  備    注:
  ********************************************************************/
  void STM32_Encrypted_ID(void)
  {
     u32 stm32ID[4],dat;   
     STM32_Read_ID(stm32ID);
     
     //這里可以用其它一些高級(jí)的算法,但解和加要一樣
     //把ID號(hào)處理成一個(gè)32位數(shù),也可以用自己的算法,處理成其他數(shù)據(jù),多少位都行
     stm32ID[3] = STM32_ID_D;        
     dat = stm32ID[0] + stm32ID[1] - (stm32ID[2]/stm32ID[3]); //處理成一個(gè)32位數(shù)
     
     FLASH_Unlock();
     FLASH_ErasePage  (STM32FLASH_EN_ID_START_ADDR);     //
     FLASH_ProgramWord(STM32FLASH_EN_ID_START_ADDR,dat); //保存這個(gè)數(shù),寫(xiě)進(jìn)32位
     FLASH_Lock();
  }
   
  /********************************************************************
  函數(shù)功能:比較加密ID,正確返回0
  入口參數(shù):
  返    回:1:不正確,0:正確
  備    注:
  ********************************************************************/
  u32 STM32_CMP_Encrypted_ID(void)
  {
     u32 stm32ID[4],dat,dat2;   
     STM32_Read_ID(stm32ID);
     
     // 這里可以用其它一些高級(jí)的算法,但解和加要一樣   
     stm32ID[3] = STM32_ID_D;      
     dat = stm32ID[0] + stm32ID[1] - (stm32ID[2]/stm32ID[3]);
     
     dat2 = *(u32*)(STM32FLASH_EN_ID_START_ADDR);  //讀出加密時(shí),保存在flash中的數(shù)
     
     if(dat == dat2){return 0;} // 相同
     else           {return 1;} // 不同
  }
   
   
  //好了,有了上面那個(gè)程序,那下再繼續(xù)
   
   
  //===================ID加密控制=====================================================================
     if(STM32_CMP_Encrypted_ID())
     {
        //量產(chǎn)時(shí)給一些條件,條件滿足就對(duì)ID加密,然后把加密結(jié)果保存到flash中,把該程序與芯片的ID,唯一對(duì)應(yīng)起來(lái),加密完后,你也可以讓它自宮。      
        if(XXXXXX)
        {
           STM32_Encrypted_ID();   //加密ID
           自宮                    //即把加密這段代碼從flash里面擦除,直接跳出去繼續(xù)執(zhí)行
        }
     }
   
   
  //===================正常運(yùn)行時(shí)==================================  
   
  // 校驗(yàn)一下ID是否正確,
     if(STM32_CMP_Encrypted_ID())
     {
      /*
      來(lái)到這里嘛,當(dāng)然不正確咯,你別讓程序死在這哦,太明顯了,很容易找到是你干的,
      那么,一個(gè)系統(tǒng)肯定有一些參數(shù)才能運(yùn)行的,你可以改變一些參數(shù),這可以讓系統(tǒng)
      有時(shí)正常有時(shí)不正常,,呵呵,要查也不是那么容易的事了
      */
     }
  }

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏4 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:608322 發(fā)表于 2021-8-31 15:38 | 只看該作者
設(shè)計(jì)好的程序,如果擔(dān)心被破解,最好id軟件加密先給我免費(fèi)破破看
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表