RC6 - RC6

RC6
RC6 Şifreleme Algoritması.JPG
Feistel işlevi RC6 algoritmasının.
Genel
TasarımcılarRon Rivest, Matt Robshaw, Ray Sidney, Yiqun Lisa Yin
İlk yayınlandı1998
Elde edilenRC5
SertifikasyonAES finalisti
Şifre ayrıntısı
Anahtar boyutları128, 192 veya 256 bit
Blok boyutları128 bit
YapısıFeistel ağı (Tip 2)[1]
Mermi20

İçinde kriptografi, RC6 (Rivest şifresi 6) bir simetrik anahtar blok şifreleme elde edilen RC5. Tarafından tasarlandı Ron Rivest, Matt Robshaw, Ray Sidney ve Yiqun Lisa Yin gereksinimlerini karşılamak için Gelişmiş Şifreleme Standardı (AES) rekabet. Algoritma beş finalistten biriydi ve aynı zamanda NESSIE ve CRYPTREC projeler. Patentli özel bir algoritmaydı. RSA Güvenliği.

RC6 uygun bir blok boyutu 128 bit ve destekler anahtar boyutları 128, 192 ve 256 bitten 2040 bit'e kadar, ancak RC5 gibi çok çeşitli kelime uzunluklarını, anahtar boyutlarını ve tur sayısını desteklemek için parametrelendirilebilir. RC6, veriye bağlı rotasyonları kullanarak yapı olarak RC5'e çok benzer, modüler ek ve ÖZELVEYA operasyonlar; Aslında, RC6, iki paralel RC5 şifreleme işleminin iç içe geçtiği olarak görülebilir, ancak RC6, dönüşü sadece en önemsiz birkaç bit değil, bir kelimedeki her bit'e bağlı kılmak için RC5'te bulunmayan ekstra bir çarpma işlemi kullanır.

Şifreleme / şifre çözme

Temel genişletme algoritmasının pratik olarak RC5 ile aynı olduğuna dikkat edin. Tek fark, RC6 için, kullanıcı tarafından sağlanan anahtardan daha fazla sözcüğün türetilmesidir.

// RC6-w / r / b ile Şifreleme / Şifre Çözme// // Giriş: Dört w-bit giriş yazmacı A, B, C ve D'de saklanan düz metin// r tur sayısıdır// w-bit yuvarlak tuşlar S [0, ..., 2r + 3]// // Çıktı: A, B, C, D'de depolanan şifreli metin// // '' 'Şifreleme Prosedürü:' ''	B = B + S[0]	D = D + S[1]	için ben = 1 -e r yapmak	{		t = (B*(2B + 1)) <<< lg w		sen = (D*(2D + 1)) <<< lg w		Bir = ((Bir  t) <<< sen) + S[2ben]		C = ((C  sen) <<< t) + S[2ben + 1] 		(Bir, B, C, D)  =  (B, C, D, Bir)	}	Bir = Bir + S[2r + 2]	C = C + S[2r + 3]// '' 'Şifre Çözme Prosedürü:' ''	C = C - S[2r + 3]	Bir = Bir - S[2r + 2]	için ben = r aşağı 1 yapmak	{		(Bir, B, C, D) = (D, Bir, B, C)		sen = (D*(2D + 1)) <<< lg w		t = (B*(2B + 1)) <<< lg w		C = ((C - S[2ben + 1]) >>> t)  sen		Bir = ((Bir - S[2ben]) >>> sen)  t	}	D = D - S[1]	B = B - S[0]

NSA "implantlarında" olası kullanım

Ağustos 2016'da, kodun Denklem Grubu veya NSA Çeşitli ağ güvenlik cihazları için "implantlar" ifşa edildi.[2] Eşlik eden talimatlar, bu programlardan bazılarının ağ iletişimlerinin gizliliği için RC6 kullandığını ortaya çıkarmıştır.[3]

Lisanslama

RC6 için seçilmediği için AES, RC6'nın telifsiz olduğu garanti edilmedi. Ocak 2017 itibarıylaRSA Laboratories, RC6 tasarımcılarının resmi web sitesinde yer alan bir web sayfası şunları belirtir:[4]

"Bunu vurguluyoruz Eğer AES için RC6 seçildiğinde, RSA Security değil algoritmayı kullanan ürünler için herhangi bir lisans veya telif hakkı ödemesi gerektirir ".

"Eğer" kelimesine yapılan vurgu, RSA Security Inc.'in RC6 algoritmasını kullanan herhangi bir ürün için lisans ve telif hakkı ödemeleri talep etmiş olabileceğini göstermektedir. RC6, patentli bir şifreleme algoritmasıdır (ABD Patenti 5,724,428 ve ABD Patenti 5.835.600 ); ancak, patentlerin süresi 2015 ile 2017 arasında doldu.

Notlar

  • Pavan, R.L .; Robshaw, M.J.B .; Sidney, R .; Yin., Y.L. (1998-08-20). "RC6 Blok Şifresi" (PDF). v1.1. Alındı 2015-08-02.

Referanslar

  1. ^ Hoang, Viet Tung; Rogaway, Phillip (2010). "Genelleştirilmiş Feistel Ağlarında". LNCS 6223. CRYPTO 2010. ABD: Springer. sayfa 613–630. doi:10.1007/978-3-642-14623-7_33.
  2. ^ "Onaylandı: Bilgisayar korsanlığı aracı sızıntısı" her şeye gücü yeten "NSA'ya bağlı gruptan geldi. Ars Technica. 16 Ağustos 2016.
  3. ^ "Bu talimatlar, NOPEN tüneli üzerinden ELIGIBLEBACHELOR kullanılarak BLATSTING KURULUMUNU yönlendirir". Alındı 2016-08-16.
  4. ^ "3.6.4 RC5 ve RC6 nedir?". RSA Laboratuvarları. Alındı 2015-08-02.

Dış bağlantılar