新聞中心

        EEPW首頁 > 模擬技術 > 設計應用 > 基于AES算法實現對數據的加密

        基于AES算法實現對數據的加密

        作者: 時間:2009-07-30 來源:網絡 收藏
        1 引言
        計算機網絡的廣泛普及與使用,電子信息技術已經滲透到了人們日常生活的各行各業,在金融、電信、政府機構等更為重要。人們越來越意識到信息安全的重要性。密碼學作為信息安全領域的一項重要技術,被普遍認為是解決信息安全保護最有效的方法。現在網絡應用的信息安全技術(如數據技術、數字簽名技術、消息論證與身份識別技術、防火墻技術以及反病毒技術等)都是以密碼學為基礎的。

        2 現代密碼學分類
        現代密碼學技術存在兩類密碼體制,分為對稱密碼體制(也稱為私鑰密碼體制)和非對稱密碼體制(也稱為公鑰密碼體制)。對稱密碼體制是較傳統的體制,主要用于保證數據的機密性,通信雙方在/解密過程中使用其共享的單一密鑰,由于其實現簡單和加密速度快等優點,目前仍然是主流密碼體制之一。對稱密碼體制分為序列密碼和分組密碼兩類,序列密碼以密鑰控制密鑰發生器,產生一個隨機序列,用這個隨機序列和明文信息逐位進行異或運算,就得到密文,其加密單元為比特。分組密碼體制將數據流分成固定長度的分組,然后再用密鑰,按照一定的把分組加密成為密文,其數據加密單元為分組。
        著名的DES標準是最常用的對稱密碼,由于技術的發展,逐漸暴露出密鑰相對過短的弊端(DES有效密鑰56位),另外,DES加密算法還存在弱密鑰和半弱密鑰以及其加密標準的算法還存在互補對稱性等缺點,2005建立了新的高級數據加密標準()規范。(Advanced Encryption Standards)是NIST旨在取代DES的新一代加密標準。

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


        3 算法
        3.1 AES加密/解密算法原理
        AES是一個迭代的、對稱密鑰分組的密碼,可使用128、192和256位密鑰,并用128位(16字節)分組加密和解密數據。與公共密鑰密碼使用密鑰對不同,對稱密鑰密碼使用相同的密鑰加密和解密數據。通過分組密碼返回的加密數據的位數與輸入數據相同。AES加密/解密框圖如圖1所示。

        3.2 算法實現舉例描述
        AES算法是基于置換和代替。置換是數據的重新排列,而代替是用一個單元數據替換另一個。AES使用了幾種不同的技術來實現置換和替換。例如以下是要加密的128位值,以及它們對應的索引數組:
        00 ll 22 33 44 55 66 77 88 99 aa bb cc dd ee ff
        O 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
        192位密鑰的值是:
        00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f 10 ll 12 13 14 15 16 17
        0 1 2 3 4 5 6 7 8 9 10 1112 13 14 15 16 17 18 19 20 2l 22 23
        AES的構造函數被調用時,用于加密方法的兩個表被初始化。第一個表的代替盒稱為S一盒。是一個16x16的矩陣。S一盒的前5行和前5列如表1所示。加密例程獲取該密鑰數組并生成一個名為w[]的密鑰調度表,如表2所示。

        w[]最初的Nk(6)行被作為種子,用原始密鑰值(0x00~0xl7)。剩余行從種子密鑰產生。變量Nk代表32位字為單位的種子密鑰長度。新的密鑰被稱為輪密鑰(round keys)。
        AES加密例程開始是拷貝16字節的輸入數組到一個名為State(態)的4x4字節矩陣中。如表3所示。AES算法的主循環對State矩陣執行4個不同的操作為:SubBytes(字節替換)、ShiftRows(行位移變換)、MixColumns(列混合變換)和AddRoundKey。
        SubBytes是一個代替操作,它將State矩陣中的每個字節替換成一個由Sbox決定的新字節。


        上一頁 1 2 下一頁

        關鍵詞: AES 算法 對數 加密

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 惠来县| 定兴县| 达日县| 班玛县| 潼南县| 安丘市| 南皮县| 防城港市| 赤峰市| 阳谷县| 招远市| 贵德县| 前郭尔| 山丹县| 纳雍县| 新晃| 夹江县| 湛江市| 金乡县| 泗洪县| 法库县| 墨玉县| 水富县| 汝南县| 景宁| 隆德县| 衡阳市| 旅游| 屏山县| 高邑县| 广元市| 隆化县| 沙洋县| 都安| 正蓝旗| 祁东县| 广汉市| 普安县| 加查县| 永靖县| 新源县|