Article cover

21.02.2023

14

Like

869

Views

DES Şifreleme

Des simetrik şifreleme algoritmasıdır. Gizli anahtarlı bir şifreleme türüdür ve büyük boyutlu verilerin şifrelenmesinde kullanılır.

  • 64 bit uzunluğundaki blokları şifreler.
  • Simetrik şifreleme, şifrelemede ve şifre çözmede aynı anahtarı kullanır.
  • 56 bitlik anahtar değeri kullanır.
  • Feistel yapıdadır.
  • Aynı işlemleri yapan 16 Rounddan oluşur.
  • Her Roundda kullanılan farklı alt anahtar, başlangıç anahtarından üretilir.




Claude Shannon İle Güçlü Şifreleme

Güçlü şifreleme algoritmaları inşa edebilmek için iki temel işlem vardır.

  1. Confusion (Karıştırma): Bir şifreleme işleminde şifreli metin ile anahtar arasında bir ilişki olmamalıdır. Günümüzde bu yapıyı sağlayan en yaygın işlem (substitution) yer değiştirmedir.
  2. Diffusion (Yayma): Sabit yaklaşımları engellemek amacıyla düz metindeki bir sembolün şifreli metindeki bir çok sembolü etkilemesi işlemidir. Sıklıkla kullanılan yapı permutasyondur.

İki işlem kendi başına güvenliği sağlayamazlar. Buradaki amaç bu iki işlemi art arda kullanarak güvenli şifreler oluşturmaktır. Des bu iki işlemi de içermesiyle güvenliği arttırmıştır.


DES Şifreleme Algoritması

Düz metin onaltılık formatta olmalıdır. Eğer değilse dönüştürme işlemi yapılır. 64 bitlik anahtar değeri tanımlanır.


Şifreleme

  1. İlk permutasyon işlemi permutasyon tablosu yardımıyla yapılır.



  1. Feistel yapısı gereği 16 rounddan oluşan işlemler uygulanır. 64 bitlik metin sağ ve sol olmak üzere iki parçaya ayrılır ve her defasında bir parçanın ve roundkey değerinin F fonksiyonuna tabi tutulup diğer parçayla XOR işlemine tabi tutulması ve sonra yer değiştirmesi sağlanır.
L = R - 1
R = L - 1 XOR F(R -1, k)


F Fonksiyonu



  • 32 bitlik sağ parça expand tablosu yardımıyla 48 bit olarak genisletilir. (Diffusion)



  • Sağ parça anahtar değeri ile XOR'lanır. (Confusion)
  • S-box yardımıyla 48 bitlik metin 32 bite indirgenir. Bunu yaparken 48 biti 6 bitlik 8 parçaya ayırır. 6 bitin ilk 2 bitinin toplamı sıra sayısını, geri kalan 4 bitin toplamı ise sutun sayısını verir. S-box tabloları yardımıyla satır ve sutun sayıları kullanılarak 4 bitlik değerler bulunur. (Diffusion)
  • 4 bitlik değerlere permutasyon tablosu yardımıyla permutasyon işlemi uygulanır. (Confisuon)



  1. Son yer değiştirmeden sonra sağ ve sol parçalar kombinasyon işleminden geçirilir.
  2. Final permutasyon işlemi final permutasyon tablosu yardımıyla uygulanır.



Şifreli metin oluşturuldu.


Anahtar Oluşturma

  1. Parity bit bırakma tablosu yardımıyla 64 bitlik anahtar permutasyon işleminden geçirilerek 56 bite indirgenmesi sağlanır. Bu ilk permutasyon işleminde parity bitleri (8, 16, 24, 32, 40, 48, 56, 64) kaldirilir. Parity bitleri kontrol bitleridir.



  1. 56 bitlik anahtar ikiye bolünür.
  2. Kaydırma tablosundan yararlanılarak 1, 2, 9 ve 16. bitler 1 kez, geri kalan bitler ise 2 kez sola kaydırılır. Kaydırma isleminden sonra anahtarlar tekrar birleştirilir.



  1. Anahtar sıkıştırma tablosu kullanılarak 56 bitlik anahtarın 48 bite indirgenmesi sağlanır. Her round için ayrı anahtar oluşturulur.


Şifre Çözme

Feistel şifrelemede şifre çözmek için sadece anahtar tarifesi değiştirilir. Aynı 16 anahtar ters çevrilerek üretilir. Ters anahtarlarla şifrelenmiş metin şifreleme fonksiyonuna tabi tutulur. Bu sayede şifre çözme işlemi gerçekleştirilir.


Kaynak kod: https://github.com/suleymangunes/des-sifreleme-python

Cryptography
İleri Python
Veri Yapıları ve Algoritmalar

Comments

You need to log in to be able to comment!

Süleyman Güneş

Yapay zeka alaninda projeler ve yarismalardan sonra ogrendiklerini mobil dunyaya tasimak icin flutter ve nodejs ogrenen bir yazılım muhendisi.

Location

İstanbul, TR

Education

yazilim muhendisligi - firat universitesi

© 2021 Patika Dev

facebook
twitter
instagram
youtube
linkedin

Disclaimer: The information /programs / events provided on https://patika.dev and https://risein.com are strictly for upskilling and networking purposes related to the technical infrastructure of blockchain platforms. We do not provide financial or investment advice and do not make any representations regarding the value, profitability, or future price of any blockchain or cryptocurrency. Users are encouraged to conduct their own research and consult with licensed financial professionals before engaging in any investment activities. https://patika.dev and https://risein.com disclaim any responsibility for financial decisions made by users based on information provided here.