新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > STM32F4 ID簡單加密

        STM32F4 ID簡單加密

        作者: 時間:2016-11-26 來源:網絡 收藏
        產品唯一的身份標識非常適合:

        ● 用來作為序列號(例如USB字符序列號或者其他的終端應用)
        ● 用來作為密碼,在編寫閃存時,將此唯一標識與軟件加解密算法結合使用,提高代碼在閃存存儲器內的安全性。
        ● 用來激活帶安全機制的自舉過程
        96位的產品唯一身份標識所提供的參考號碼對任意一個STM32微控制器,在任何情況下都是唯一的。用戶在何種情況下,都不能修改這個身份標識。
        這個96位的產品唯一身份標識,按照用戶不同的用法,可以以字節(8位)為單位讀取,也可以以半字(16位)或者全字(32位)讀取。
        基地址:0x1FFF 7A10 ------stm32f4xx對應的,本文章基于F4的地址

        本文引用地址:http://www.104case.com/article/201611/321883.htm

        (基地址:0x1FFF F7E8 ------stm32f1xx對應的)

        每個CPU 出廠的時候都
        配置的一個ID,96 位的.這個唯一碼可以利用作軟件加密.......


        static u32 CpuID[3];
        static u32 Lock_Code;


        void GetLockCode(void)
        {
        //獲取CPU唯一ID
        CpuID[0]=*(vu32*)(0x1fff7a10);
        CpuID[1]=*(vu32*)(0x1fff7a14);
        CpuID[2]=*(vu32*)(0x1fff7a18);
        //加密算法,很簡單的加密算法
        Lock_Code=(CpuID[0]>>1)+(CpuID[1]>>2)+(CpuID[2]>>3);
        }

        然后再用上次所用的 FLASH_ProgramWord(LOCK_ADDR,Lock_Code); 寫到FLASH 的某個角落就好了,然后再在程序中驗證這個值是否正確。感覺ID的調取很是方便倒是加密算法讓人頭痛,當然了要是把MD5移植過來應該不是太難。



        關鍵詞: STM32F4ID簡單加

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 武陟县| 宜州市| 山阴县| 阳原县| 永顺县| 元阳县| 双峰县| 图们市| 东城区| 上饶市| 邢台市| 简阳市| 铜川市| 凉城县| 保靖县| 剑川县| 永胜县| 宽甸| 汉沽区| 芦溪县| 容城县| 吐鲁番市| 弋阳县| 西丰县| 和林格尔县| 信阳市| 杂多县| 浠水县| 辽中县| 搜索| 永新县| 九江市| 贵州省| 项城市| 梁平县| 汤阴县| 阳泉市| 沧州市| 弥勒县| 鄂伦春自治旗| 绥江县|