每日資訊:專克量子計算機的超級密碼 被10年前的老爺機干碎了
最近美國科研圈估計很頭大。就在上個月美國國家標準與技術研究所( NIST )結束了一項為期 6 年的國際競賽,目的是尋找對抗量子計算機的加密算法。之所以,有這么個競賽,實在是加密專業的人的活的太慘,堪比國內的土木專業。自從量子計算機出現,各個學科都贏麻了,唯獨搞密碼學的崩潰了。
訪問:
阿里云1核2G云服務器低至1折 最高可得500元滿減優惠券
(資料圖片)
這源于密碼學一向叛逆的定位:別的學科是為了算出一個答案,密碼學是防止別人算出一個答案。
因此,量子計算機直接對密碼學帶來了 “ 連根拔起 ” 的威脅。
拿最常見的 RSA-2048 算法舉例,這個算法是由 2048 位長的加密信息組成的,即使是最先進超級計算機也需要 3 千萬年才能破解。( 日本的富岳超級計算機,計算速度 442 Pflop/s )
但是量子計算只需要 8 個小時。( 使用窮舉法,一個一個的試 )
這就導致量子計算機原則上可以快速破解大多數的加密算法。
為了應對這種量子層面威脅,世界各地的密碼學家在過去的二十年里一直在設計用來抵抗量子計算機攻擊的后量子加密算法,并誕生了相應的算法競賽。
不過,更戲劇的是,這個競賽剛宣布結果沒多久,8 強選手之一的 SIKE 算法,就被人滿血給秒了。
而且,SIKE 算法是被一臺十年前的臺式機,用單核處理器在 4 分鐘內破解了低安全版本,并在一個小時內破解了該算法的最強形態。
這有多麻瓜呢?
和 SIKE 安全級別相同的 RSA3068 算法,用目前最先進的超級計算機破解,(日本的富岳超級計算機,計算速度 442 Pflop/s。)需要大約 2 萬億年的時間,比宇宙存在的時間都要長。
然而, SIKE 算法,在一臺 10 年前的英特爾單核臺式機面前,只堅持了一個小時。
一個對抗量子計算機的超級算法,被臺式機給擊敗了,這離譜程度不亞于哥斯拉,被咱們的二踢腳給炸飛了。
不過,差評君仔細研究了一下發現:這可能只是一個嚴肅科學界的烏龍事件。
這個名為 SIKE 的算法之所以 “ 一碰就碎 ”,還得從算法的內核說起。
在這個幺蛾子之前,SIKE 算的上是 21 世紀的算法新星了。這個算法是一種基于超橢圓曲線的年輕加密算法。在它誕生的 12 年里,一直在加強,從未被超越。
它最大的賣點,在超高的性價比上 —— 安全性很高,而且體積還小。
一個由 335 個數字組成的 SIKE 算法,和由 3068 個數字組成的常用算法( RSA 算法 ),安全性是同一級別的。
這就好像用十進制來表達二進制的數字,不僅方便,而且更加簡潔。
在 NIST 收集的 90 多種后量子算法中,SIKE 及其衍生的算法占據了絕對的上風,成為最短后量子密碼中的的前 16 強。
也正是因此,SIKE 算法一直有不少的擁護者,想要見證和創造歷史。
不過,有趣的是,這個算法的破解者托馬斯 · 德克魯也是其中之一。
托馬斯是這么描述他的破解過程的:
一天,托馬斯在和同事沃特 · 卡斯特里克,在研究 SIKE 算法,試圖用來增強其他密碼的安全性。
結果在研究相關文獻的時候,發現了一篇 1997 年的論文。
論文中,有一個 “ 幾乎立即適用于 SIKE 算法 ” 的定理,以至于他們在兩天之內 “ 反向加強 ” 了 SIKE 算法,并用臺式機破解了它。
這就邪門了呀,要知道在此之前這個算法的破解已經 10 年沒有進展了,而托馬斯只用了兩天,甚至還寫出了一個沒有 bug 的破解程序。
不僅是密碼學家,就連程序員都得羞愧難當了。
8 月 5 日,他們在一篇論文中記錄了這一神奇的破解方法:
雖然橢圓曲線是一維對象,但在數學中,橢圓曲線可以被可視化為二維或任何其他維數的對象。人們可以在這些廣義對象之間創建同源。
通過應用一個 25 年前的定理,新的攻擊使用 SIKE 公開的額外信息來構建二維的同源。然后這種同源性就可以重建 SIKE 用來加密消息的密鑰。
專業以外的人其實很難理解,這一過程的有趣之處。
做一個不是很恰當的比方:
這個 SIKE 算法就像一個平面幾何問題( 也就是二維問題 ),專門用來對抗量子計算機的運算能力,因為平面幾何的難點在于畫輔助線。讓計算機一條一條地試輔助線,不知道得試到什么時候去了。但是 Thomas 將這個圖形三維化了,它變成空間向量坐標系的問題。
這樣子,這個問題就可以通過列方程組來解決,這就又回到計算的范疇了。
所以,這一次破解 SIKE 算法的關鍵,被歸功于數學之神的青睞。
對此,有位密碼學家對這個算法的破解給予了高度的評價,“ 我懷疑:世界上只有不到 50 人掌握了破解 SIKE 算法必要的數學和密碼學知識。”
當然,我也懷疑這個密碼學家是在強行找回面子。
因為這個問題的破解者,只是一個非著名大學 “ 魯汶大學 ” 的博士后,甚至不是 NIST 密碼破解組的成員,而是一個業余愛好者。
也有大佬比較客觀地表示:“ 我們應該做好剩下的 7 個選手都被干掉的準備,畢竟所有的密碼在被破解之前,看起來都很可靠。”
總而言之,自從 1981 年量子計算機的概念被提出以來,算法的加密和破解之間的戰斗,比之前的幾千年都要劇烈。
在此之前,密碼學的圣經是:“ 想要密碼更安全?簡單加大計算量就行了 ”。
相較于計算機運算速度的發展,將加密信息從 100 位增加到 1000 位,或者是將一種算法更換成更復雜的算法,就已經夠用了。但是,后量子時代要求密碼學家的思維更加開闊。
比如,這次競賽中的另一個種子選手 -- 格算法( Ring learning with errors )就是一個格局非常打開的存在。格算法看起來比較簡單,像是一個將經典問題放在坐標系里。
但是它這個坐標系有些霸道,為了保證安全性,這個坐標系的維度常年保持在 1000 維以上。這就相當于,大家還在做一元二次方程的年紀,你已經在進行 1000 元二次方程的求解了。
同樣是九年義務教育,為啥你這么優秀呢?當然,這也只是冰山一角。
過去幾十年,整個密碼學都被量子計算機,這一個沒有落地的概念給唬住了,然后開始拼了命的逃亡。我們見證了密碼學的崩潰、重構,甚至衍生出了一種理論上無敵的量子密碼,想要找回場子。科學,真是太 tm 魔幻了。
關鍵詞: 專克量子計算機的超級密碼 被10年前的老爺機干碎了
2022-09-09 06:57:47
2022-09-09 06:56:55
2022-09-09 06:55:17
2022-09-09 06:52:40
2022-09-09 06:51:46
2022-09-09 06:51:43
2022-09-09 06:50:40
2022-09-09 06:42:05
2022-09-09 06:34:12
2022-09-09 06:32:13
2022-09-08 21:35:54
2022-09-08 21:32:44
2022-09-08 19:52:28
2022-09-08 19:47:24
2022-09-08 19:47:21
2022-09-08 19:40:01
2022-09-08 19:36:25
2022-09-08 18:52:51
2022-09-08 18:40:10
2022-09-08 18:38:16
2022-09-08 18:33:54
2022-09-08 17:52:45
2022-09-08 17:46:52
2022-09-08 17:44:28
2022-09-08 17:40:21
2022-09-08 17:39:09
2022-09-08 17:36:28
2022-09-08 17:36:05
2022-09-08 17:29:10
2022-09-08 16:42:39
2022-09-08 15:51:52
2022-09-08 15:51:47
2022-09-08 15:45:22
2022-09-08 15:42:47
2022-09-08 15:39:47
2022-09-08 15:38:52
2022-09-08 15:38:31
2022-09-08 15:37:45
2022-09-08 15:31:38
2022-09-08 15:30:28
2022-09-08 15:29:28
2022-09-08 09:50:21
2022-09-08 09:45:04
2022-09-08 09:37:32
2022-09-08 09:36:00
2022-09-08 09:32:04
2022-09-08 09:22:20
2022-09-08 08:51:11
2022-09-08 08:49:22
2022-09-08 08:47:54
2022-09-08 08:46:51
2022-09-08 08:46:09
2022-09-08 08:41:10
2022-09-08 08:36:05
2022-09-08 08:29:02
2022-09-08 06:49:01
2022-09-08 06:42:49
2022-09-08 06:42:44
2022-09-08 06:38:10
2022-09-08 06:33:16
2022-09-08 05:52:42
2022-09-08 05:52:12
2022-09-08 05:49:35
2022-09-08 05:49:07
2022-09-08 05:48:41
2022-09-08 05:46:47
2022-09-08 05:44:07
2022-09-08 05:44:02
2022-09-08 05:42:54
2022-09-08 05:35:46
2022-09-07 22:47:02
2022-09-07 22:42:36
2022-09-07 22:39:36
2022-09-07 22:39:08
2022-09-07 22:38:50
2022-09-07 22:32:30
2022-09-07 21:57:22
2022-09-07 21:48:14
2022-09-07 21:47:26
2022-09-07 21:46:54
2022-09-07 21:39:59
2022-09-07 21:38:08
2022-09-07 21:33:56
2022-09-07 21:28:21
2022-09-07 20:53:32
2022-09-07 20:53:13
2022-09-07 20:51:54
2022-09-07 20:49:09
2022-09-07 20:47:21
2022-09-07 20:38:44
2022-09-07 20:37:10
2022-09-07 20:36:27
相關新聞