<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

          EEPW首頁 > 安全與國防 > 設(shè)計(jì)應(yīng)用 > 在ARM微處理器上實(shí)現(xiàn)Rijndael加密算法

          在ARM微處理器上實(shí)現(xiàn)Rijndael加密算法

          ——
          作者: 時(shí)間:2006-06-09 來源: 收藏

          引 言
              2000年10月2日,美國國家標(biāo)準(zhǔn)局NIST宣布,比利時(shí)密碼學(xué)家Joat Daemen和Vincent Rijmen設(shè)計(jì)的“RijndaeI算法”以安全性好、運(yùn)算速度快、存儲要求低、靈活性強(qiáng)最終當(dāng)選AES。該算法對目前的各種威脅是免疫的。這標(biāo)志著信息技術(shù)有了新的安全工具,為計(jì)算機(jī)網(wǎng)絡(luò)和電子商務(wù)的發(fā)展提供了強(qiáng)有力的保障。
              在當(dāng)前數(shù)字信息技術(shù)和網(wǎng)絡(luò)技術(shù)高速發(fā)展的后PC時(shí)代,技術(shù)已經(jīng)廣泛地滲透到科學(xué)研究、工程設(shè)計(jì)、軍事技術(shù)、各類產(chǎn)業(yè)和商業(yè)文化藝術(shù)以及人們的日常生活等方方面面中,成為目前最熱門的技術(shù)之一。
              本文使用北京博創(chuàng)興業(yè)科技有限公司研制的UP-NETARM300嵌入式開發(fā)板,在ARM SDT 2.51集成開發(fā)環(huán)境下,建立基于μC/OS-Il操作系統(tǒng)的工程文件,分別調(diào)用ARM匯編程序和C程序在嵌入式微處理器上實(shí)現(xiàn)了Rijndael算法,并比較了兩者的效率。下面以分組長度和密鑰長度都是128位為例,介紹調(diào)用ARM匯編程序?qū)崿F(xiàn)加密算法的過程。本實(shí)現(xiàn)算法可以將密鑰長度擴(kuò)展
          到192位或256位。


          1 Rijndael加密算法簡介
          1.1 算法流程結(jié)構(gòu)

              Rijndael加密算法的128位輸入分組用以字節(jié)為單位的正方形矩陣描述。該數(shù)組被復(fù)制到State數(shù)組。加密過程分為四個(gè)階段:密鑰擴(kuò)展、輪密鑰加、Nr-1(對應(yīng)128、192、256位密鑰長度,Nr分別為10、12、14)輪變換及最后一輪變換。輪變換包括字節(jié)代換、行移位、列混淆和輪密鑰加四個(gè)過程,最后一輪變換包括字節(jié)代換、行移位和輪密鑰加三個(gè)過程。用偽C代碼表示如下:

          Rijndael (State, CipherKey)  {

          KeyExpansion (CipherKey, ExpandKey);  //密鑰擴(kuò)展

          AddRoundKey (State, RoundKey);  //輪密鑰加

          For (i=1;i<Nr;i++)  

          Round (State, ExpandKey+4*i);  //輪變換

          FinalRound (State, ExpandKey+4 * Nr);  //最后一輪變換}

          Round (State, RoundKey){  //輪變換

          SubByte (State);  //字節(jié)代換

          ShiftRow(State);  //行移位

          MixColumn(State);  //列混淆

          AddRoundKey(State, RoundKey);  輪密鑰加

          FinalRound(State, RoundKey) {  //最后一輪變換

          SubByte(State);

          ShiftRow(State);

          AddRoundKey(State,RoundKey); 
          1. 2算法所使用的主要變換
          (1)字節(jié)代換SubByte
              用一個(gè)簡單的查表操作代替了基于矩陣乘法的復(fù)雜仿射變換。Rijndael定義了一個(gè)16



          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();