Feistel Block Cipher
Feistel Cipher bukanlah skema khusus dari block cipher. Ini adalah model desain dari mana banyak cipher blok yang berbeda diturunkan. DES hanyalah salah satu contoh dari Feistel Cipher. Sistem kriptografi berdasarkan struktur sandi Feistel menggunakan algoritma yang sama untuk enkripsi dan dekripsi.
Proses Enkripsi
Proses enkripsi menggunakan struktur Feistel yang terdiri dari beberapa putaran pemrosesan teks biasa, setiap putaran terdiri dari langkah "substitusi" yang diikuti dengan langkah permutasi.
Struktur Feistel ditunjukkan pada ilustrasi berikut -
Blok masukan untuk setiap putaran dibagi menjadi dua bagian yang dapat dilambangkan sebagai L dan R untuk bagian kiri dan bagian kanan.
Di setiap babak, bagian kanan dari blok, R, tidak mengalami perubahan. Tetapi bagian kiri, L, menjalani operasi yang bergantung pada R dan kunci enkripsi. Pertama, kami menerapkan fungsi enkripsi 'f' yang mengambil dua input - kunci K dan R. Fungsi tersebut menghasilkan output f (R, K). Kemudian, kami XOR output dari fungsi matematika dengan L.
Dalam implementasi nyata dari Feistel Cipher, seperti DES, alih-alih menggunakan seluruh kunci enkripsi selama setiap putaran, kunci bergantung-bulat (subkunci) diturunkan dari kunci enkripsi. Ini berarti bahwa setiap putaran menggunakan kunci yang berbeda, meskipun semua subkunci ini terkait dengan kunci asli.
Langkah permutasi pada akhir setiap putaran menukar L yang dimodifikasi dan R. yang tidak dimodifikasi. Oleh karena itu, L untuk putaran berikutnya adalah R dari putaran saat ini. Dan R untuk putaran berikutnya menjadi keluaran L dari putaran saat ini.
Langkah substitusi dan permutasi di atas membentuk 'putaran'. Jumlah putaran ditentukan oleh desain algoritma.
Setelah putaran terakhir selesai maka dua sub blok, 'R' dan 'L' digabungkan dalam urutan ini untuk membentuk blok ciphertext.
Bagian tersulit dalam mendesain Cipher Feistel adalah pemilihan fungsi bulat 'f'. Untuk menjadi skema yang tidak dapat dipecahkan, fungsi ini perlu memiliki beberapa properti penting yang berada di luar cakupan diskusi kita.
Proses Dekripsi
Proses dekripsi di sandi Feistel hampir serupa. Alih-alih memulai dengan satu blok teks biasa, blok teks tersandi dimasukkan ke awal struktur Feistel dan kemudian proses selanjutnya persis sama seperti yang dijelaskan dalam ilustrasi yang diberikan.
Prosesnya dikatakan hampir mirip dan tidak persis sama. Dalam kasus dekripsi, satu-satunya perbedaan adalah bahwa subkunci yang digunakan dalam enkripsi digunakan dalam urutan terbalik.
Pertukaran terakhir dari 'L' dan 'R' di langkah terakhir dari Feistel Cipher sangat penting. Jika ini tidak ditukar maka ciphertext yang dihasilkan tidak dapat didekripsi menggunakan algoritma yang sama.
Jumlah Putaran
Jumlah putaran yang digunakan dalam Feistel Cipher tergantung pada keamanan yang diinginkan dari sistem. Lebih banyak putaran memberikan sistem yang lebih aman. Tetapi pada saat yang sama, lebih banyak putaran berarti proses enkripsi dan dekripsi lambat yang tidak efisien. Jumlah putaran dalam sistem dengan demikian bergantung pada tradeoff efisiensi-keamanan.