Drcrypt
DrCrypt şifreleme algoritması, temel XOR(Özel Veya) işlemine dayanır. DrCrypt, hızlı ve
güvenilir olmak üzere geliştirilmiştir. 1 adet 2048 elemandan oluşan "Bilgi Gölgeleyici"
sabitler dizisine sahiptir. İçeriği tahmin edilmesi yüksek bilgilerin açıklarını kapatmak
ve bu sisteme fazladan güvenlik getirmek için eklenmiştir.
DrCrypt, kullanıcının belirttiği şifreden 32 adet sabit şifreleme anahtarı ve
her bilgiye sırasına özel ve benzersiz(teoride) bir "Uzunluk Damgası" atar. Sabit dizi
elemanları("Bilgi Gölgeleyiciler") bu damganın oluşturulmasında kullanılır.
DrCrypt algoritmasında şifreleme ve çözme işlemleri aynı yolla yapılır. Şifreleme
işlemi için önce bilgi "Uzunluk Damgası" ile XOR(Özel Veya) işlemine sokulur. Daha sonra sırası
gelen şifreleme anahtarı("32'li ") ile XOR(Özel Veya) işlemine sokulur.
Proje Detayları[değiştir]
DrCrypt herhangi bir lisans anlaşmasına bağlı olmayan özgür bir teknolojidir. Kullanım, değiştirme ve geliştirme için izin gerektirmez. DrCrypt projesi şu anda "Source Forge" sitesinden dağıtılmaktadır. Proje Java, .NET, Win32 platformlarını destekler.Proje Web Sitesi 4 Aralık 2013 tarihinde Wayback Machine sitesinde arşivlendi.
DrCrypt Algoritmasının Detayları (Tam Anlatımı)[değiştir]
Adım 1 - [ Şifreye Bağlı Sayı Üretme (Üretim Fonksiyonu) ]
a)- Şifre uzunluğu hesaplanır.
b)- Şifre uzunluğunun n-1 * n+1 hali hesaplanır.
c)- 0 (Sıfır)'a eşit olan geçici bir tam sayı; 1'den şifrenin uzunluğuna
kadar kendisi, "1" (Bir, Her adımda eklenerek) ve şifrenin her char
(karakter) değerinin ASCII tablosundaki karşılığı ile toplanır.
d)- (Şifre Uzunluğunu - 1 * Şifre Uzunluğunu + 1) işlemi sonucuna sahip
tam sayı, 1'den şifrenin uzunluğuna kadar kendisi, adım sayısı ve 1
(Bir, Her adımda eklenerek) ile toplanarak hazırlanır.
e)- Şifrenin her hali ile benzersiz olması ve diziliminin değişiminden
ötürü bir şifrenin alternatiflerinin ortaya çıkmasını engellemek için bir
benzersizlik prosedürü uygulanır.
Benzersizlik prosedüründe, 1'den şifre uzunluğuna kadar şifrenin
ilk iki karakterinden başlayarak(her adımda 1 kayarak) ilk iki
karakterin ASCII değeri toplamı, 1. karakterin ASCII toplamı ile
modüler aritmetik işlemine sokulur ve çıkan sonuç bir tam sayıya
aktarılır ve her adımda sonuç bu tam sayıya eklenerek ilerler.
(İşlem şifre uzunluğu-1 kez sürer.)
Benzersizlik rakamı ASCII tablosunda birbirini takip eden
şifreler için aynıdır ancak yine de benzersizliği sağlar.
Karakter farkları bunu sağlar. Benzersizlik rakamı sadece
şifrenin kullanılan karakter ve dizilimine ait bir ek
bildirgeçtir.
f)- Sonuç olarak şifreleme çözme sayısı aşağıdaki gibi hesaplanır.
Şifreleme/Çözme Sayısı =
(bkz. madde c) Geçici Tamsayi +
(bkz. madde a)Sifre Uzunluğu +
(bkz. madde b)Sifre Uzunluk Türevi +
(bkz. madde e)Sifre Benzersizlik Faktörü
Değerlerin toplanması ile oluşan sonuç ile anahtarlar üretilir.
Adım 2 - [ A, B, C, D Parametrelerinin Hesaplanması ]
A = Şifreleme/Çözme sayısının sayı değeri
B = Şifreleme/Çözme sayısının çarpmalı sayı değeri. (0'lar hariç)
C = 1'den Şifreleme/Çözme sayısına kadar olan asal sayıların sayısı.
D = 1'den Şifreleme/Çözme sayısına kadar olan ve Şifreleme/Çözme sayısı ile aralarında asal olan sayıların sayısı.
Yukarıdakiler hesaplandığında "T Dörtgeni" isimli bir yapı oluşur.
Kare değil de dörtgen denmesinin sebebi; her parametrenin bir kenarı
temsil etmesi ve her birinin birbirinden farklı olmasıdır.
Adım 3 - [ Sekiz adet güçlendirilmiş "T Dörtgeni" hesaplama prosedürü. ]
Bu adımda Şifreleme/Çözme sayısı ile A, B, C, D parametreleri kullanılarak
1 olan dörtgen sayısı 8'e çıkarılır. Burada kullanılan X, Y, Z, P her adımda
gereken geçici tam sayı saklayıcılardır.
Dörtgen 1 = (X = A Xor B), (Y = D + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 2 = (X = A Xor B), (Y = C + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = z + P)
Dörtgen 3 = (X = B Xor C), (Y = A + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 4 = (X = B Xor C), (Y = D + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 5 = (X = C Xor A), (Y = B + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 6 = (X = C Xor A), (Y = D + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 7 = (X = B Xor D), (Y = C + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Dörtgen 8 = (X = B Xor D), (Y = A + 1), (Z = X + 1), (P = Sayi Mod Y), (Sonuç = Z + P)
Adım 4) - Ham Şifreleme Anahtarları Olan M, N, O, P parametrelerinin hesaplanması
! - Bu parametreler ile 32 adet temel şifreleme anahtarı üretilecektir.
M Parametresi = (A= _0 * _1), (B = A Mod _5), (C = _6 + B), (Sonuç = C)
N Parametresi = (A= _4 * _5), (B = A Mod _1), (C = _2 + B), (Sonuç = C)
O Parametresi = (A= _5 * _6), (B = A Mod _2), (C = _3 + B), (Sonuç = C)
P Parametresi = (A= _7 * _6), (B = A Mod _2), (C = _1 + B), (Sonuç = C)
Adım 5) - 32 Adet Temel Anahtarın Oluşturulması
>>> Not: Parantezler önemlidir. İşlem sırası karışmamalıdır.
AnahtarKutusu[00] = ((((M) Xor (M)) + (M) ) * M )
AnahtarKutusu[01] = ((((M) Xor (M)) + (M) ) * N )
AnahtarKutusu[02] = ((((M) Xor (M)) + (N) ) * O )
AnahtarKutusu[03] = ((((M) Xor (M)) + (N) ) * P )
AnahtarKutusu[04] = ((((M) Xor (N)) + (O) ) * M )
AnahtarKutusu[05] = ((((M) Xor (N)) + (O) ) * N )
AnahtarKutusu[06] = ((((M) Xor (N)) + (P) ) * O )
AnahtarKutusu[07] = ((((M) Xor (N)) + (P) ) * P )
AnahtarKutusu[08] = ((((N) Xor (O)) + (M) ) * M )
AnahtarKutusu[09] = ((((N) Xor (O)) + (M) ) * N )
AnahtarKutusu[10] = ((((N) Xor (O)) + (N) ) * O )
AnahtarKutusu[11] = ((((N) Xor (O)) + (N) ) * P )
AnahtarKutusu[12] = ((((N) Xor (P)) + (O) ) * M )
AnahtarKutusu[13] = ((((N) Xor (P)) + (O) ) * N )
AnahtarKutusu[14] = ((((N) Xor (P)) + (P) ) * O )
AnahtarKutusu[15] = ((((N) Xor (P)) + (P) ) * P )
AnahtarKutusu[16] = ((((O) Xor (M)) + (M) ) * M )
AnahtarKutusu[17] = ((((O) Xor (M)) + (M) ) * N )
AnahtarKutusu[18] = ((((O) Xor (M)) + (N) ) * O )
AnahtarKutusu[19] = ((((O) Xor (M)) + (N) ) * P )
AnahtarKutusu[20] = ((((O) Xor (N)) + (O) ) * M )
AnahtarKutusu[21] = ((((O) Xor (N)) + (O) ) * N )
AnahtarKutusu[22] = ((((O) Xor (N)) + (P) ) * O )
AnahtarKutusu[23] = ((((O) Xor (N)) + (P) ) * P )
AnahtarKutusu[24] = ((((P) Xor (O)) + (M) ) * M )
AnahtarKutusu[25] = ((((P) Xor (O)) + (M) ) * N )
AnahtarKutusu[26] = ((((P) Xor (O)) + (N) ) * O )
AnahtarKutusu[27] = ((((P) Xor (O)) + (M) ) * P )
AnahtarKutusu[28] = ((((P) Xor (P)) + (O) ) * M )
AnahtarKutusu[29] = ((((P) Xor (P)) + (O) ) * N )
AnahtarKutusu[30] = ((((P) Xor (P)) + (P) ) * O )
AnahtarKutusu[31] = ((((P) Xor (P)) + (P) ) * P )
Adım 6) - "Uzunluk Damgası"' nın Hesaplanması
Uzunluk damgası şifreleme/çözme prosedürleri her işletildiğinde tekrar hesaplanır.
a). Uzunluk Damgasi = Şifreleme/Çözme Sayisi Xor Yapilan Giriş Sayısı(32 bit tam sayı olarak) + Bilgi Gölgeleyici(1..2048 adresindeki değerler) + Golgeleyici Eleman Numarası(1..2048) + Anahtar Sıra Bileti(1..32) b). Uzunluk Damgasi = Uzunluk Damgasi + 1
DrCrypt ile 32 bit Genişliğinde Bir Tam sayı Bilginin Şifrelenmesi Ve Çözülmesi
Şifreleme için ... a). Sonuç 1 = Bilgi XOR Uzunluk Damgası b). Final Sonuç = Sonuç 1 XOR Anahtar(Sırası Gelen)
Çözümleme için ... a). Sonuç 1 = Bilgi XOR Uzunluk Damgası b). Final Sonuç = Sonuç 1 XOR Anahtar(Sırası Gelen)
Çekirdek İşlem Tanımı[değiştir]
Aşağıdaki Delphi(Win32) kodunda temel şifreleme/çözme yapan prosedür verilmiştir.
Inc(YapilanGiris); { Yapılan INT32 giriş sayısı (GirisSayisi/4 = Byte Sayısı) }
Inc(GolgeleyiciElemanNo); { Gölgeleyici Eleman Numarası Artışı }
Inc(SiraBileti); { Anahtar Sıra Bileti }
if GolgeleyiciElemanNo = 2048 then
begin
GolgeleyiciElemanNo := 0;
end;
if SiraBileti = 32 then
begin
SiraBileti := 0;
end;
{ 32 bit işlemcili bilgisayarlarda bilgi kaybı ve hafıza taşmasını
engellemek için yapılmış bir düzeltmedir. INT32 değerinin pozitif
maximum tepe değerinden fazla olan her giriş düzeltilir. }
if YapilanGiris >= High(Tamsayi) then
begin
YapilanGiris := Abs((YapilanGiris) - (High(Tamsayi)));
end;
UzunlukDamgasi := (SifrelemeCozmeSayisi) Xor
(YapilanGiris + BilgiGolgeleyici[GolgeleyiciElemanNo] + GolgeleyiciElemanNo + SiraBileti);
Inc(UzunlukDamgasi); { Uzunluk Damgasının Tam Benzersizliğini
(teorik olarak) sağlar. Uygulamada benzersizlik bozulabilmektedir. }
{ Bilginin int32 formatında uzunluğu ve konumu sayesinde elde ettiği
benzersiz uzunluk damgası. XOR gibi basit bir yöntemi zorlaştıran
en temel etkenlerden birisi budur.}
if UzunlukDamgasi >= High(Tamsayi) then
begin
UzunlukDamgasi := Abs((UzunlukDamgasi) - (High(Tamsayi)));
end;
tmp1 := ((Bilgi) Xor ((UzunlukDamgasi))); { Şifreleme ADIM 1 }
tmp2 := ((tmp1) Xor (AnahtarKutusu[SiraBileti])); { Şifreleme ADIM 2 }
Result := tmp2; { Bilgi Başarıyla Şifrelendi }
Kaynakça[değiştir]
http://drcrypt.sourceforge.net 4 Aralık 2013 tarihinde Wayback Machine sitesinde arşivlendi.
This article "Drcrypt" is from Wikipedia. The list of its authors can be seen in its historical and/or the page Edithistory:Drcrypt. Articles copied from Draft Namespace on Wikipedia could be seen on the Draft Namespace of Wikipedia and not main one.