摘? 要: 綜述了對Rijndael算法所提出的各種攻擊并對其進(jìn)行分析。同時對一些可能會導(dǎo)致對Rijndael攻擊的新理論和研究結(jié)果做了分析和討論。
關(guān)鍵詞: Rijndael? 攻擊方法? 安全性分析
?
2000年10月,美國國家標(biāo)準(zhǔn)技術(shù)研究所(NIST)宣布Rijndael被確定為高級加密標(biāo)準(zhǔn)(AES)。本文給出目前攻擊Rijndael密碼的一些主要方法。
關(guān)于Rijndael的完整密碼的系統(tǒng)規(guī)范本文并沒有詳細(xì)描述,讀者可以參考文獻(xiàn)[6]。本文僅對Rijndael算法所提出的攻擊作一個整體的概述。另外還介紹了目前已經(jīng)公布的可能可以破解Rijndael密碼的思想。表1中總結(jié)了對于給定密鑰長度所能攻破的方法的復(fù)雜性、攻擊的輪數(shù)。在表1中已經(jīng)公布的能攻破Rijndael密碼的輪數(shù)都小于Rijndael密碼的規(guī)定的輪數(shù)。例如,在2000年公布的基于不可能差分分析(impossible differential)的攻擊方法只能對于6輪的128位密鑰進(jìn)行攻擊,而其標(biāo)準(zhǔn)是10輪。
表1中,幾乎所有的攻擊(除了在2001年公布的攻擊方法外)都是在NIST將其作為AES標(biāo)準(zhǔn)之前就已經(jīng)公布了。因此可以得到結(jié)論:到目前為止,對于Rijndael密碼的攻擊還沒有比窮盡密鑰搜索攻擊更有效的方法,已經(jīng)公布的攻擊思想不能形成有效的攻擊。
?
對于Rijndael密碼更詳細(xì)的攻擊的討論的一些新思想將在下文中詳細(xì)討論。在后一部分列舉和簡單討論了目前已知的對Rijndael密碼的攻擊方法,在第3部分對最近提出來的攻擊Rijndael密碼的新思想(代數(shù)攻擊)進(jìn)行討論。
1? 對Rijndael密碼的攻擊
1.1 差分和線性分析
差分和線性分析方法是到目前為止二種最有用的通用密碼分析方法。對于這些攻擊提供輪數(shù)低的復(fù)雜度是在設(shè)計Rijndael密碼時的最基本的準(zhǔn)則。
對于Rijndael密碼來說,已經(jīng)證明對于一個4輪的Rijndael密碼來說,差分分析方法的概率上限是2-150,線性分析方法的概率上限是2-75。結(jié)合實(shí)際Rijndael密碼的輪數(shù),這些輪數(shù)對于抵抗上述攻擊能夠提供足夠的安全性。對于這方面更詳細(xì)的討論可以參考文獻(xiàn)[6]。
1.2 變量法
在變量法公布之后,線性和差分攻擊方法在某些方面已經(jīng)做了擴(kuò)展,也公布了一些和它相關(guān)的攻擊方法。最好的擴(kuò)展方法是截段差分分析法(truncated differentials)。但是在設(shè)計Rijndael密碼的時候就已經(jīng)考慮到這種攻擊方法,Rijndael密碼能夠比較好地抵抗這種攻擊。其他的攻擊方法還有:
不可能差分攻擊:差分密碼攻擊是利用高概率特征或差分恢復(fù)密鑰,不可能差分攻擊是利用概率為0(或非常小)的特征或差分,其基本思想是排除那些導(dǎo)致概率為0(或非常小)的特征或差分的候選密鑰。對5輪的Rijndael密碼,可以用不可能差分攻擊方法,它要求229.5個選擇明文、231個密文、242個存儲字和226小時的預(yù)先處理時間,該結(jié)果在參考文獻(xiàn)[4]中做了改進(jìn),使得它可以攻擊6輪的Rijndael密碼。但是對于輪數(shù)更高的Rijndael密碼,采用該方法攻擊則沒有更好的效果。
Square攻擊:對Rijndael密碼分析最有效的就是Square攻擊,它是一個選擇明文攻擊,通過研究基于字節(jié)結(jié)構(gòu)的密文來進(jìn)行攻擊。它對于和Rijndael密碼的其中一輪有相似結(jié)構(gòu)的任何密文都是有效的。這種攻擊的其他名字還有“飽和攻擊”(Lucks在參考文獻(xiàn)[11]中提出,這種攻擊能夠破解具有7輪的192位和256位Rijndael密碼),L.Knudsen和D.Wagner提出的“積分密碼分析”,以及A.Biryukov和A.Shamir提出的“結(jié)構(gòu)攻擊”。
最初的Square攻擊對6~7輪的Rijndael密碼(例如AES-128和AES-192)的破解比窮盡密鑰搜索攻擊快。N.Ferguson等在減少破解的工作方面做了一些優(yōu)化,因此,它能夠在有256位相關(guān)密碼的277個明文,2224個密文,破解9輪的AES-256密碼。
Collision攻擊:這種攻擊是由Gilbert和Minier提出[9],它對于破解7輪的AES-128、AES-192、AES-256仍然是最好的破解方法。
2? 一些新的理論和分析
盡管前面介紹了能夠?qū)喕腞ijndael密碼的攻擊方法,但是這些方法對Rijndael密碼本身的攻擊并沒有任何效果。上述的大多數(shù)攻擊方法都和稱為“代數(shù)攻擊”的方法有關(guān),可以簡要地歸納為如下步驟:
(1)收集信息階段:密碼分析者將密文表達(dá)為有很多變量的一系列簡單方程。這些變量包括明文、密文和密鑰中的位或字節(jié),還有一些中間計算結(jié)果和輪密鑰。
(2)攻擊階段:密碼分析者利用輸入的數(shù)據(jù),例如明文—密文對等,代替在第一步中得到的方程中的變量,并且用各種辦法將方程解出來,這樣就可以根據(jù)求出的變量來恢復(fù)密鑰。
按照Rijndael密碼的設(shè)計原則,Rijndael密碼是用一些比較巧妙的方程表達(dá)式來實(shí)現(xiàn)的。雖然從單純的數(shù)學(xué)角度來看,要從這些方程組表達(dá)式得到密碼的密鑰非常困難,但是也可能利用其他的一些方法比較容易地解決。已經(jīng)有一些方法利用Rijndael密碼的代數(shù)結(jié)構(gòu)來破解密碼。但是到目前為止還沒有能夠進(jìn)行有效攻擊的方法,大多數(shù)文章的結(jié)論還有待于進(jìn)一步研究和探討。下面討論在這方面最新的一些研究成果和理論。
(1)連分式。Ferguson,Schroeppel和Whiting[8]得出一個關(guān)于Rijndael密碼的閉公式,該公式可以看作是由一個連分式生成的。在5輪以后中間結(jié)果的任何字節(jié)都可以表示為如下表達(dá)式:
????
在上述表達(dá)式中,每個K是一個字節(jié),它依賴于擴(kuò)充了的密碼中的一些字節(jié);每個Ci是一個已知的常數(shù);每個*是一個給定的指數(shù)或下標(biāo)。但是這些值依賴于它們所包含符號的求和變量。一個完全擴(kuò)展的式(1)的版本有225項。為了破解一個10輪的Rijndael密碼(AES-128),密碼分析者可以通過二個這種類型的方程來利用計算的中間結(jié)果。第一個方程可以將5輪以后的中間變量作為明文字節(jié)函數(shù);第二方程可以將6~10輪以后的中間變量作為明文字節(jié)函數(shù)。結(jié)合二個方程可以得到一個含有226個未知變量的方程。通過重復(fù)這個方程226/16個給定的明文/密文對,從信息理論的意義上來說,就有足夠多的信息能夠解出未知變量。但是到目前為止,還沒有任何人公開發(fā)表能夠具體地去尋找一種算法來解決這樣一類問題的方程。
(2)XSL。Courtois and Pieprzyck[5]通過研究發(fā)現(xiàn),在Rijndael密碼中使用的S-盒可以通過一系列隱含的二次布爾方程表達(dá)。用字母x1,……x8表示輸入的位,用字母y1,……y8表示輸出的位。則存在如下形式的等式:
其中函數(shù)f為二次方程。
從理論上來說,只需要8個像(2)式的方程就能夠定義S-盒,但是Courtois and Pieprzyck經(jīng)研究發(fā)現(xiàn),能夠構(gòu)建多于所需要的方程個數(shù)。此外,他們還宣稱這些特定的方程可以有助于簡化解決問題的復(fù)雜性。他們發(fā)現(xiàn)一個算法,該算法在處理這個問題的時間復(fù)雜度低于指數(shù)??墒怯泻芏嗟难芯空邞岩伤麄冇嬎愕恼_性。例如Don Coppersmith曾說過“我堅信Courtois-Pieprzyk的工作是有漏洞的。他們把線性獨(dú)立的方程個數(shù)估計過多了,他們所得到的結(jié)果事實(shí)上沒有足夠的線性方程來解決問題”。此外,他還說“這種方法有一定的優(yōu)點(diǎn),也值得去研究,但是并不能像他們所說的那樣能夠破解Rijndael密碼?!盩.Moh也懷疑他們計算方法的正確性。無論如何,在假設(shè)他們的計算方法正確的前提下,破解密碼的復(fù)雜性的最好估計是2255步(對于不同參數(shù)的復(fù)雜性的計算可以參見文獻(xiàn)[5]的8.1節(jié))。這就意味著,他們的攻擊僅僅可以破解Rijndael密碼為256位的密鑰(AES-256)。因為相應(yīng)的窮盡密鑰搜索攻擊的復(fù)雜度為2256?,F(xiàn)在還不清楚Rijndael密碼的什么屬性影響到該攻擊的復(fù)雜性。這種攻擊方法對AES的影響不會太大,因為即使這種攻擊方法完全正確,AES的安全性也比DES好得多。
(3)嵌入法。Murphy and Robshaw[12]定義了分組密碼BES,它是對128字節(jié)為一組而不是128位為一組的對象來處理。按照Murphy and Robshaw的觀點(diǎn),BES密碼的代數(shù)結(jié)構(gòu)甚至比Rijndael密碼的代數(shù)結(jié)構(gòu)更簡單。此外,Rijndael密碼能夠被嵌入BES密碼中,也就是說有如下映射φ:
在這個方程中,K代表密鑰,x代表明文。Murphy and Robshaw通過研究得出BES的一些性質(zhì)。但是BES的屬性不能轉(zhuǎn)換為Rijndael密碼的性質(zhì)。
Murphy and Robshaw相信,如果將XSL方法應(yīng)用到BES,則解決步驟的復(fù)雜性將比直接將XSL方法應(yīng)用到Rijndael密碼的復(fù)雜性大大降低。
(4)雙密文攻擊。在文獻(xiàn)[1]中介紹了雙密文的概念,它基本是“嵌入”技術(shù)的歸納。其基本內(nèi)容為:如果取三個不可逆映射f,g和h,則存在一個雙密文DUAL滿足:
????
在這個方程中,K代表密文密鑰,x代表明文。這個方程表示對于一個給定的明文和密鑰雙密文產(chǎn)生相同的密文文本。從這個意義上來說,雙密文等價于原來的密文。因此,可以實(shí)現(xiàn)和分析雙密文而不是原來的密文。在文獻(xiàn)[1]中確定了Rijndael密碼中的240個雙密文。到現(xiàn)在,還沒有關(guān)于雙密文有何漏洞的報導(dǎo)。一個類似的概念,稱為Rijndael-GF[6]。已經(jīng)證明,對于抵抗差分和線性密碼分析,Rijndael-GF族密碼系統(tǒng)的密文都具有相同的安全性。
(5)Plaintext-dependent Repetition Codes攻擊。2003年1月8號,Eric Filiol發(fā)表了一篇文章[3],在該文中他宣稱可以用一種非常簡單、快速和惟密文的攻擊方法來攻擊AES。其基本思想是:假設(shè)pi,ci和ki分別為AES的明文、密文和密鑰位。這些位的變化范圍總是0~127,0是第一個字節(jié)的最重要的位,127是最后一個字節(jié)最不重要的一個位。例如c71是密文中第9個字節(jié)的最重要的位。在文章中,作者宣稱如果明文是以形式:
?
以大概是0.50003的概率成立。如果該論斷能成立,則該方法對AES的攻擊大約只須231步即可。目前,這種論斷還沒有取得一致的認(rèn)可,有些密碼分析者懷疑其正確性。
3? 結(jié)束語
在本文中,主要展示和討論了到目前為止,所有關(guān)于Rijndael密碼系統(tǒng)的密碼分析成果。此外還討論了有可能能夠破解Rijndael密碼的一些新的可能的攻擊方法。但是有些方法還有待于進(jìn)行進(jìn)一步的證明和探討。
?
參考文獻(xiàn)
1? Barkan E,Biham E.In how many ways can you write?Rijndael?In:Proceedings of Asiacrypt′02,Queenstown,
New Zealand,2002
2? 馮登國.密碼分析學(xué).北京:清華大學(xué)出版社,2000
3? 楊義先,孫偉,鈕心.現(xiàn)代密碼新理論.北京:科學(xué)出版社,2002
4? Cheon J H,Kim M J,Kim K et al.Improved Impossible Differential Cryptanalysis of Rijndael and Cryp? ton,Information Security and Cryptology-ICISC 2001,2001
5? Courtois N T,Pieprzyk J.Cryptanalysis of block?ciphers with overdefined systems of equations.In:
Proceedings of Asiacrypt′02,Queenstown,New Zealand,2002
6? Daemen J,Rijmen V.The Design of Rijndael.Information Security and Cryptography,Springer Verlag,2002
7? Ferguson N,Kelsey J,Lucks S et al.Improved cryptanalysis of Rijndael.In:Proceedings of Fast Software
Encryption-FSE′00,New York,NY,USA,April,2000
8? Ferguson N,Schroeppel R,Whiting D.A simple algebraic representation of Rijndael.In:Proceedings of
Selected Areas in Cryptography-SAC′01,Toronto,Ontario,Canada,August,2001
9? Gilbert H,Minier M.Acollision attack on seven rounds of Rijndael.In:Proceedings of the Third Advanced
Encryption Standard Conference,New York,USA, April,2000
10? Knudsen L R,Wagner D.Integral cryptanalysis(extended abstract).In:Proceedings of Fast Software
Encryption-FSE′02,Leuven,Belgium,February,2002
11? Lucks S.Attacking seven rounds of Rijndael under 192-bit and 256-bit keys.In:Proceedings of the
Third Advanced Encryption Standard Conference,New York,USA,April,2000
12? Murphy S,Robshaw M J B.Essential algebraic structure within the AES.In:Proceedings of Crypto′02,
Santa Barbara,California,USA,2002