利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)
生活随笔
收集整理的這篇文章主要介紹了
利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
源:利用STM32F唯一96bit序列號實現反拷貝加密的源代碼公開
//--------------------------------------------------------------------------- #include #pragma argsused BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fwdreason, LPVOID lpvReserved) {return 1; } //--------------------------------------------------------------------------- //本示例代碼用BCB5編寫,很容易移植到VC++等編譯環境 //導出函數mcuisp_AntiCopy,mcuisp.exe將調用mcuisp_AntiCopy函數來實現反拷貝功能 extern "C" __declspec(dllexport) int __stdcall mcuisp_AntiCopy(unsigned char *buf, //FLASH內容存儲緩沖DWORD buflen, //FLASH代碼長度(字節)DWORD startaddress, //FLASH的地址偏移,STM32F一般為0x08000000unsigned char const *inbuf, //前12字節為96bit的芯片序列號DWORD inputbuflen //序列號信息的長度 ); //-- int __stdcall mcuisp_AntiCopy(unsigned char *buf, //FLASH內容存儲緩沖DWORD buflen, //FLASH代碼長度(字節)DWORD startaddress, //FLASH的地址偏移,STM32F一般為0x08000000unsigned char const *inbuf, //前12字節為96bit的芯片序列號DWORD inputbuflen //序列號信息的長度 ) {//mcuisp_AntiCopy根據FLASH內容和芯片序列號,經過運算后,修改FLASH內容//本例中,簡單的把序列號拷貝到0x08010000的位置//可以在STM32的代碼中比對0x08010000和0x1ffff7e8的內容,相符才正常運行//實際應用中,可以采取比較復雜的算法memcpy(buf+0x10000,inbuf,12);return 0; };上述DLL與mcuisp配合,即可實現STM32F AntiCopy功能。
由于算法由用戶自己把握,自由發揮,可最大限度保護用戶的代碼
?
轉載于:https://www.cnblogs.com/LittleTiger/p/4597438.html
總結
以上是生活随笔為你收集整理的利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 《人件集 人性化的软件开发》阅读笔记01
- 下一篇: rabiitmq