Rabin şifreleme sistemi

testwiki sitesinden
19.10, 9 Şubat 2025 tarihinde imported>İmmoBot tarafından oluşturulmuş 1479 numaralı sürüm (Örnek: Ayraç kullanımı düzeltiliyor., değiştirildi: ’ → ' (2))
(fark) ← Önceki sürüm | Güncel sürüm (fark) | Sonraki sürüm → (fark)
Gezinti kısmına atla Arama kısmına atla

Rabin şifreleme sistemi, Rabin kriptoloji veya Rabin kriptosistemi, güvenliği RSA'daki gibi tam sayı çarpanlarına ayırmanın zorluğu üzerine kurgulanmış olan asimetrik bir kriptografik tekniktir. Bununla birlikte, Rabin kriptosisteminin avantajı, saldırgan tam sayıları verimli bir şekilde çarpanlarına ayıramadığı sürece, seçilmiş bir düz metin saldırısına karşı hesaplama açısından güvenli olduğu matematiksel olarak kanıtlanmıştır, oysa RSA için bilinen böyle bir kanıt yoktur.[1]Şablon:Rp Rabin fonksiyonunun her çıktısının dört olası girdiden herhangi biri tarafından üretilebilmesi dezavantajı; her çıktı bir şifreli metinse, olası dört girdiden hangisinin gerçek düz metin olduğunu belirlemek için şifre çözmede ekstra karmaşıklık gerekir.

Tarihçe

Algoritma Ocak 1979'da Michael O. Rabin tarafından yayınlandı.[2] Rabin şifreleme sistemi, şifreli metinden düz metni kurtarmanın çarpanlara ayırma kadar zor olduğu kanıtlanabilen ilk asimetrik şifreleme sistemiydi.

Şifreleme algoritması

Tüm asimetrik şifreleme sistemleri gibi, Rabin şifreleme sistemi de bir anahtar çifti kullanır: şifreleme için genel anahtar ve şifre çözme için özel anahtar. Genel anahtar, herkesin kullanması için yayınlanırken, özel anahtar yalnızca mesajın alıcısı tarafından bilinir.

Anahtar üretimi

Rabin şifreleme sisteminin anahtarları şu şekilde oluşturulur:

  1. İki tane çok büyük ve farklı p, q asal sayıları seçilir. Kare kökün hesaplanmasını basitleştirmek için bir tanesini pq3(mod4) yöntemi ile seçebiliriz. Fakat yöntem herhangi daha büyük asal sayılarla çalışır.
  2. n=pq hesaplanır. Burada n açık anahtar, asal sayılardan oluşan (p,q) ise özel anahtardır.

Şifreleme

Bir M mesajı, önce tersine çevrilebilir bir eşleme kullanılarak m<n sayısına dönüştürülerek ve ardından c=m2(modn) hesaplanarak şifrelenebilir. Şifreli metin, c'dir.

Şifre çözme

m mesajı, şifreli c metninden karekök modül n'si aşağıdaki gibi alınarak elde edilebilir.

  1. Aşağıdaki formülleri kullanarak c modül p ve q'nun karekökünü hesaplayın;
    mp=c14(p+1)(modp)mq=c14(q+1)(modq)
  2. ypp+yqq=1 olacak şekilde yp ve yq'i bulmak için Genişletilmiş Öklid algoritması kullanın.
  3. c modül n'nin dört karekökünü bulmak için Çin kalan teoremi'ni kullanın:
    r1=(yppmq+yqqmp)(modn)r2=nr1r3=(yppmqyqqmp)(modn)r4=nr3

Bu dört değerden biri orijinal düz metin m'dir, ancak dördünden hangisinin doğru olduğu ek bilgi olmadan belirlenemez.

Kesin anahtar üretimi süreci aşağıdaki gibidir:

Karekökleri hesaplama

Yukarıdaki 1. adımdaki formüllerin aslında c'in kareköklerini aşağıdaki gibi ürettiğini gösterebiliriz. İlk formül için, mp2c(modp) olduğunu kanıtlamak istiyoruz. p3(mod4) olduğundan, 14(p+1) üssü bir tam sayıdır. c0(modp) ise ispat önemsizdir, bu nedenle p'nin c'yi bölmediğini varsayabiliriz. cm2(modpq) ögesinin cm2(modp) anlamına geldiğini unutmayın, dolayısıyla c modül p'ye göre bir kuadratik kalıntıdır (rezidü). Buradan;

mp2c12(p+1)cc12(p1)c1(modp)

yazılabilir. Son adım Euler ölçütü tarafından doğrulanır.

Deşifreleme şifreli metninin kare köklerini hesaplamak için c mod asal sayı p ve q'yu gerektirir.

mp=c(p+1)4(modp) ve
mq=c(q+1)4(modq) olur.

Biz bu metodun p için çalışmasını aşağıdaki gibi gösterebiliriz. İlk (p+1)4'ün, p3(mod4) bir tam sayı olduğunu gösterir. c0(modp) için varsayım basittir. Bu yüzden biz p'nin c'ye bölünmediğini varsayabiliriz. O zaman:

mp2c(p+1)2cc(p1)2c(cp)(modp),
(cp) Legendre sembolüdür.
cm2(modpq)'dan aşağıdaki gibi
cm2(modp) olarak hesaplanır.

Bu yüzden x, modül p'nin kuadratik kalanıdır. Buradan;

(cp)=1 ve
mp2c(modp) elde edilir.
p3(mod4) ilişkisi bir gereksinim değildir. Çünkü kare kökler in diğer asal sayılarla modülü de hesaplanabilir.

Rabin kare köklerin asal sayılarla modlarını bulmak için Berlekamp algoritmasının özel bir durumunu kullanmayı önerir.

Örnek

Örnek olarak, p=7 ve q=11 olarak alalım, ardından n=77 olur (Elbette burada anahtarların seçimi kötüdür. 77'nin çarpanlarına ayrılması basittir gerçek örneklerde çok çok daha büyük sayılar kullanılır). Düz metnimiz olarak m=20 alalım. Şifreli metin bu şekilde

c=m2(modn)=400(mod77)=15 olarak elde edilir.

Bizim basit örneğimizde P={0,,76} bizim düz metin uzayımızdır. Biz m=20'yi bizim düz metnimiz olarak alacağız. Bu yüzden şifreli metin, c=m2(modn)=400(mod77)=15'dir. Açıkça m'nin 4 farklı değeri m{13,20,57,64} için, şifreli metin 15 üretilir. Bu Rabin algoritması tarafından üretilen çoğu şifreli metinler için geçerlidir.

Şifre çözme işlemi şu şekilde ilerler:

  1. mp=c14(p+1)(modp)=152(mod7)=1 ve mq=c14(q+1)(modq)=153(mod11)=9 hesaplanır.
  2. yp=3 ve yq=2'yi hesaplamak için genişletilmiş Öklid algoritması kullanılır. ypp+yqq=(37)+(211)=1 olduğunu doğrulayabiliriz.
  3. Dört düz metin adayını hesaplayın:
    r1=(379+2111)(mod77)=64r2=7764=13r3=(3792111)(mod77)=𝟐𝟎r4=7720=57

ve r3'in istenen düz metin olduğunu görüyoruz. Dört adayın hepsinin 15 mod 77'nin karekökleri olduğuna dikkat edin. Yani, her aday için ri2(mod77)=15, böylece her ri aynı değere (15) şifreler.

Eğer c ve r bilinirse düz metin m2c(modr) ile m{0,,n1} olacaktır. r bir kompozit sayıdır kompozit sayı asal olmayan herhangi bir pozitif sayıdan daha büyük pozitif sayı demektir. Eğer N>0 bir tam sayı ise ve N=a×b gibi 1<a,b<N sayısı var ise o zaman N kompozit sayı demektir (yani Rabin algoritmasının n=pq formülüne benzer). m'yi bulmak için bilinen daha etkili bir metot yoktur. Eğer asal ise (Rabin algoritmasındaki p ve q gibi) Çin kalan teoremi m'nin çözümü için başvurulabilecek bir metottur. Bu yüzden kare kökler;

mp=c(modp) ve
mq=c(modq) hesaplanmış olmalıdır.

Bizim örneğimizde mp=1 ve mq=9 alalım, Genişletilmiş Öklid Algoritması uygulanarak biz yp ve yq'yu bulmak isteyelim. ypp+yqq=1 ile bulunur. Bizim örneğimizde yp=3 ve yq=2 bulunur.

Şimdi, Çin kalan teoremi yardımıyla, c+n/n'nin dört karekökü +r, r, +s ve s şeklinde hesaplanır (burada /n, modn uyum sınıfları halkası [ring of congruence classes] anlamına gelir.) 4 kare kök {0,,n1} kümesi içindedir:

r=(yppmq+yqqmp)(modn)r=nrs=(yppmqyqqmp)(modn)s=ns'dir.

Bu kare köklerin bir tanesi modn orijinal düz metin m'dir. Bizim örneğimizde m{64,𝟐𝟎,13,57}'dir.

Rabin kendi makalesinde eğer bir kişi hem r hem de s'yi hesaplayabilirse o zaman n'nin çarpanlarını da hesaplayabileceğini bize şöyle gösteriyor;

ya gcd(|rs|,n)=p ya gcd(|rs|,n)=q, burada gcd (Greatest Common Divisor) yani en büyük ortak bölen (EBOB) anlamına gelir.

Çünkü eğer bir kişi r ve s'yi biliyorsa, en büyük ortak bölen n'nin çarpanlarını bulmak için etkili bir hesaplama yöntemidir bizim örneğimizde (57 ve 13r ve s olarak alalım):

gcd(5713,77)=gcd(44,77)=11=q bulunur.

Dijital İmza Algoritması

Rabin şifreleme sistemi, dijital imza'lar oluşturmak ve doğrulamak için kullanılabilir. İmza oluşturmak için (p,q) özel anahtarı gerekir. Bir imzanın doğrulanması için n ortak anahtarı gerekir.

İmzalama

Bir m<n mesajı, bir özel anahtar (p,q) ile aşağıdaki gibi imzalanabilir.

  1. Rastgele bir u değeri oluşturun.
  2. c=H(m|u)'i hesaplamak için bir H kriptografik özet fonksiyonunu kullanın, buradaki | notasyonu birleştirmeyi (Şablon:Dil) gösterir. c, n değerinden küçük bir tam sayı olmalıdır.
  3. c'yi Rabin tarafından şifrelenmiş bir değer olarak ele alın ve özel anahtarı (p,q) kullanarak şifresini çözmeye çalışın. Bu, olağan şekilde dört r1,r2,r3,r4 sonucunu üretecektir.
  4. Her bir ri şifrelemenin c üreteceği beklenebilir. Ancak, bu yalnızca c bir kuadratik kalıntı mod p ve q olursa doğru olacaktır. Durumun böyle olup olmadığını belirlemek için, ilk şifre çözme sonucunu r1 şifreleyin. c olarak şifrelemezse, bu algoritmayı yeni bir rastgele u ile tekrarlayın. Uygun bir c bulmadan önce bu algoritmanın tekrarlanması gereken beklenen tekrar sayısı 4'tür.
  5. c olarak şifreleyen bir r1 bulduktan sonra, imza (r1,u) olur.

İmzanın doğrulanması

m mesajı için bir (r,u) imzası, n genel anahtarı kullanılarak aşağıdaki gibi doğrulanabilir.

  1. c=H(m|u)'yi hesapla.
  2. r'yi n ortak/açık anahtarını kullanarak şifrele.
  3. İmza, ancak ve ancak r şifrelemesinin c'ye eşit olması durumunda geçerlidir.

Algoritmanın değerlendirilmesi

Etkinlik

Şifre çözme, doğru sonuca ek olarak üç yanlış sonuç üretir, böylece doğru sonucun tahmin edilmesi gerekir. Bu, Rabin şifreleme sisteminin en büyük dezavantajıdır ve yaygın pratik kullanım bulmasını engelleyen faktörlerden biridir.

Düz metnin bir metin mesajını temsil etmesi amaçlanıyorsa, tahmin etmek zor değildir; bununla birlikte, eğer düz metin sayısal bir değeri temsil etmeyi amaçlıyorsa, bu konu, bir tür belirsizliği giderme şemasıyla çözülmesi gereken bir problem haline gelir. Bu problemi ortadan kaldırmak için özel yapılara sahip düz metinler seçmek veya dolgu eklemek mümkündür. Tersine çevirmenin belirsizliğini ortadan kaldırmanın bir yolu Blum ve Williams tarafından önerilmiştir: kullanılan iki asal sayı, 3 modül 4 ile uyumlu asal sayılarla sınırlandırılmıştır ve kare alma alanı, ikinci dereceden kalıntılar kümesiyle sınırlandırılmıştır. Bu kısıtlamalar, kare alma fonksiyonunu bir tuzak kapı permütasyonuna dönüştürerek belirsizliği ortadan kaldırır.[3]

Verimlilik

Şifreleme için bir kare modül n hesaplanmalıdır. Bu, en az bir küpün hesaplanmasını gerektiren RSA'dan daha verimlidir.

Şifre çözme için, iki modüler üsle birlikte Çin kalan teoremi uygulanır. Burada verimlilik RSA ile karşılaştırılabilir.

Belirsizliği giderme, ek hesaplama maliyetleri getirir ve Rabin şifreleme sisteminin yaygın pratik kullanım bulmasını engelleyen şeydir.Şablon:Cn

Güvenlik

Rabin ile şifrelenmiş bir değerin şifresini çözen herhangi bir algoritmanın n modülünü çarpanlara ayırmak için kullanılabileceği kanıtlanmıştır. Bu nedenle, Rabin şifre çözme en az tam sayı çarpanlarına ayırma problemi kadar zordur, bu RSA için kanıtlanmamış bir şeydir. Genellikle çarpanlara ayırma için polinom-zaman algoritması olmadığına inanılır, bu da özel anahtar (p,q) olmadan Rabin ile şifrelenmiş bir değerin şifresini çözmek için verimli bir algoritma olmadığı anlamına gelir.

Rabin şifreleme sistemi, şifreleme süreci deterministik olduğu için seçilen düz metin saldırılarına karşı ayırt edilemezlik sağlamaz. Bir şifreli metin ve bir aday mesaj verilen bir rakip, şifreli metnin aday mesajı kodlayıp kodlamadığını kolayca belirleyebilir (sadece aday mesajı şifrelemenin verilen şifreli metni verip vermediğini kontrol ederek).

Rabin şifreleme sistemi, seçilen bir şifreli metin saldırısına karşı güvensizdir (sorgulama mesajları, mesaj uzayından homojen bir biçimde rastgele seçilse bile).[1]Şablon:Rp Fazlalıklar, örneğin son 64 bitin tekrarı eklenerek, sistem tek bir kök üretmek için yapılmıştır. Bu, seçilen şifreli metin saldırısını engeller, çünkü şifre çözme algoritması yalnızca saldırganın zaten bildiği kökü üretir. Eğer bu teknik uygulanırsa, çarpanlara ayırma problemi ile denkliğin ispatı başarısız olur, bu yüzden bu varyantın güvenli olup olmadığı 2004 itibarıyla belirsizdir. Menezes, Oorschot ve Vanstone tarafından hazırlanan Handbook of Applied Cryptography,[4] köklerin bulunması iki parçalı bir süreç olduğu sürece (1. modp ve modq kökleri ve 2. Çin kalan teoreminin uygulaması) bu eşdeğerliğin muhtemel olduğunu düşünmektedir.

Notlar

Şablon:Kaynakça

Ayrıca bakınız

Kaynakça

Dış bağlantılar

Şablon:Açık anahtarlı şifreleme

Şablon:Otorite kontrolü