Sandi Tradisional

Di bab kedua, kami membahas dasar-dasar kriptografi modern. Kami menyamakan kriptografi dengan toolkit di mana berbagai teknik kriptografi dianggap sebagai alat dasar. Salah satunya adalah Symmetric Key Encryption dimana kunci yang digunakan untuk enkripsi dan dekripsi adalah sama.

Dalam bab ini, kita membahas teknik ini lebih jauh dan aplikasinya untuk mengembangkan berbagai sistem kriptografi.

Sistem Kriptografi Sebelumnya

Sebelum melangkah lebih jauh, Anda perlu mengetahui beberapa fakta tentang cryptosystems historis -

  • Semua sistem ini based on symmetric key encryption skema.

  • Satu-satunya layanan keamanan yang disediakan sistem ini adalah kerahasiaan informasi.

  • Tidak seperti sistem modern yang digital dan memperlakukan data sebagai bilangan biner, sistem sebelumnya bekerja pada huruf sebagai elemen dasar.

Sistem kriptografi sebelumnya ini juga disebut sebagai Cipher. Secara umum, sandi hanyalah sekumpulan langkah (algoritme) untuk melakukan enkripsi dan dekripsi yang sesuai.

Caesar Cipher

Ini adalah sandi mono-alfabet di mana setiap huruf dari teks biasa diganti dengan huruf lain untuk membentuk teks sandi. Ini adalah bentuk skema sandi substitusi yang paling sederhana.

Sistem kriptografi ini umumnya disebut sebagai Shift Cipher. Konsepnya adalah mengganti setiap alfabet dengan alfabet lain yang 'digeser' oleh beberapa angka tetap antara 0 dan 25.

Untuk jenis skema ini, baik pengirim maupun penerima menyetujui 'nomor shift rahasia' untuk menggeser alfabet. Angka antara 0 dan 25 ini menjadi kunci enkripsi.

Nama 'Caesar Cipher' kadang-kadang digunakan untuk menggambarkan Shift Cipher ketika 'shift of three' digunakan.

Proses Shift Cipher

  • Untuk mengenkripsi huruf teks biasa, pengirim memposisikan penggaris geser di bawah rangkaian huruf teks biasa pertama dan menggesernya ke KIRI dengan jumlah posisi shift rahasia.

  • Huruf plaintext tersebut kemudian dienkripsi menjadi huruf ciphertext pada penggaris geser di bawahnya. Hasil dari proses ini digambarkan dalam ilustrasi berikut untuk perpindahan tiga posisi yang disepakati. Dalam hal ini, 'tutorial' teks biasa dienkripsi ke teks sandi 'WXWRULDO'. Berikut adalah alfabet ciphertext untuk Pergeseran 3 -

  • Saat menerima ciphertext, penerima yang juga mengetahui secret shift, menempatkan penggaris gesernya di bawah alfabet ciphertext dan menggesernya ke KANAN dengan nomor shift yang disepakati, 3 dalam kasus ini.

  • Dia kemudian mengganti huruf ciphertext dengan huruf plaintext pada penggaris geser di bawahnya. Karenanya ciphertext 'WXWRULDO' didekripsi menjadi 'tutorial'. Untuk mendekripsi pesan yang dikodekan dengan Shift 3, buat alfabet teks biasa menggunakan pergeseran '-3' seperti yang ditunjukkan di bawah ini -

Nilai Keamanan

Caesar Cipher adalah not a securecryptosystem karena hanya ada 26 kemungkinan kunci untuk dicoba. Seorang penyerang dapat melakukan pencarian kunci yang lengkap dengan sumber daya komputasi yang terbatas.

Sandi Substitusi Sederhana

Ini merupakan perbaikan dari Caesar Cipher. Alih-alih menggeser alfabet dengan beberapa angka, skema ini menggunakan beberapa permutasi huruf dalam alfabet.

Misalnya, AB… ..YZ dan ZY …… BA adalah dua permutasi yang jelas dari semua huruf dalam alfabet. Permutasi tidak lain adalah kumpulan huruf yang campur aduk.

Dengan 26 huruf dalam alfabet, kemungkinan permutasi adalah 26! (Faktorial 26) yaitu sama dengan 4x10 26 . Pengirim dan penerima dapat memilih salah satu dari kemungkinan permutasi ini sebagai alfabet ciphertext. Permutasi ini adalah kunci rahasia dari skema.

Proses Penyandi Substitusi Sederhana

  • Tuliskan huruf A, B, C, ..., Z dalam urutan aslinya.

  • Pengirim dan penerima memutuskan permutasi huruf-huruf alfabet yang dipilih secara acak.

  • Di bawah urutan abjad natural, tulis permutasi yang dipilih dari huruf-huruf alfabet. Untuk enkripsi, pengirim mengganti setiap huruf teks biasa dengan mengganti huruf permutasi yang berada tepat di bawahnya dalam tabel. Proses ini diperlihatkan dalam ilustrasi berikut. Dalam contoh ini, permutasi yang dipilih adalah K, D, G, ..., O. 'Titik' teks biasa dienkripsi menjadi 'MJBXZ'.

Berikut adalah alfabet Ciphertext campur aduk, di mana urutan huruf ciphertext adalah kuncinya.

  • Saat menerima ciphertext, penerima, yang juga mengetahui permutasi yang dipilih secara acak, mengganti setiap huruf ciphertext di baris bawah dengan huruf teks biasa yang sesuai di baris atas. Ciphertext 'MJBXZ' didekripsi menjadi 'point'.

Nilai Keamanan

Simple Substitution Cipher merupakan peningkatan yang cukup besar dari Caesar Cipher. Jumlah tombol yang mungkin besar (26!) Dan bahkan sistem komputasi modern belum cukup kuat untuk meluncurkan serangan brute force dengan nyaman untuk menghancurkan sistem. Namun, Simple Substitution Cipher memiliki desain yang sederhana dan rentan terhadap kekurangan desain, katakanlah memilih permutasi yang jelas, kriptosistem ini dapat dengan mudah dipatahkan.

Sandi Monoalphabetic dan Polyalphabetic

Sandi monoalphabetic adalah sandi substitusi di mana untuk kunci tertentu, alfabet sandi untuk setiap alfabet biasa ditetapkan selama proses enkripsi. Misalnya, jika 'A' dienkripsi sebagai 'D', untuk sejumlah kemunculan dalam teks biasa itu, 'A' akan selalu dienkripsi menjadi 'D'.

Semua sandi substitusi yang telah kita diskusikan sebelumnya di bab ini adalah monoalphabetic; cipher ini sangat rentan terhadap pembacaan sandi.

Sandi Polialfabetik adalah sandi pengganti di mana sandi alfabet untuk alfabet biasa mungkin berbeda di tempat yang berbeda selama proses enkripsi. Dua contoh berikutnya,playfair and Vigenere Cipher are polyalphabetic ciphers.

Playfair Cipher

Dalam skema ini, pasangan huruf dienkripsi, bukan huruf tunggal seperti dalam kasus sandi substitusi sederhana.

Dalam playfair cipher, awalnya tabel kunci dibuat. Tabel kuncinya adalah kisi huruf berukuran 5 × 5 yang berfungsi sebagai kunci untuk mengenkripsi teks biasa. Masing-masing dari 25 huruf harus unik dan satu huruf dari alfabet (biasanya J) dihilangkan dari tabel karena kita hanya membutuhkan 25 huruf, bukan 26. Jika teks biasa berisi J, maka diganti dengan I.

Pengirim dan penerima deicide pada kunci tertentu, katakan 'tutorial'. Dalam tabel kunci, karakter pertama (dari kiri ke kanan) dalam tabel adalah frasa, tidak termasuk huruf duplikat. Sisa tabel akan diisi dengan sisa huruf alfabet, dalam urutan yang wajar. Tabel kunci berhasil menjadi -

Proses Playfair Cipher

  • Pertama, pesan teks biasa dibagi menjadi pasangan dua huruf (digraf). Jika ada jumlah huruf ganjil, Z ditambahkan ke huruf terakhir. Katakanlah kita ingin mengenkripsi pesan "sembunyikan uang". Ini akan ditulis sebagai -

    HI DE MO NE YZ

  • Aturan enkripsi adalah -

    • Jika kedua huruf berada di kolom yang sama, ambil huruf di bawah masing-masing (kembali ke atas jika di bawah)

  • T U HAI R saya 'H' dan 'I' ada di kolom yang sama, maka ambil huruf di bawahnya untuk diganti. HI → QC
    SEBUAH L S B C
    D E F G H.
    K M N P. Q
    V. W X Y Z
  • Jika kedua huruf berada di baris yang sama, ambil huruf di sebelah kanan masing-masing (kembali ke kiri jika paling kanan)

  • T U HAI R saya 'D' dan 'E' berada di baris yang sama, maka ambil huruf di sebelah kanannya untuk diganti. DE → EF
    SEBUAH L S B C
    D E F G H.
    K M N P. Q
    V. W X Y Z
  • Jika tidak satu pun dari dua aturan sebelumnya benar, bentuk persegi panjang dengan dua huruf dan ambil huruf pada sudut horizontal berlawanan dari persegi panjang.

Dengan menggunakan aturan ini, hasil enkripsi 'sembunyikan uang' dengan kunci 'tutorial' adalah -

QC EF NU MF ZV

Mendekripsi sandi Playfair semudah melakukan proses yang sama secara terbalik. Penerima memiliki kunci yang sama dan dapat membuat tabel kunci yang sama, lalu mendekripsi pesan apa pun yang dibuat menggunakan kunci tersebut.

Nilai Keamanan

Ini juga merupakan sandi substitusi dan sulit dipecahkan dibandingkan dengan sandi substitusi sederhana. Seperti dalam kasus substitusi sandi, kriptanalisis juga dimungkinkan pada sandi Playfair, namun akan melawan 625 kemungkinan pasangan huruf (25x25 alfabet) alih-alih 26 kemungkinan alfabet berbeda.

Sandi Playfair digunakan terutama untuk melindungi rahasia yang penting, namun tidak penting, karena cepat digunakan dan tidak memerlukan peralatan khusus.

Vigenere Cipher

Skema sandi ini menggunakan string teks (katakanlah, sebuah kata) sebagai kunci, yang kemudian digunakan untuk melakukan sejumlah pergeseran pada teks biasa.

Misalnya, anggap saja kuncinya adalah 'titik'. Setiap alfabet kunci diubah ke nilai numeriknya masing-masing: Dalam hal ini,

p → 16, o → 15, i → 9, n → 14, dan t → 20.

Jadi, kuncinya adalah: 16 15 9 14 20.

Proses Vigenere Cipher

  • Pengirim dan penerima memutuskan sebuah kunci. Katakan 'titik' adalah kuncinya. Representasi numerik dari kunci ini adalah '16 15 9 14 20 '.

  • Pengirim ingin mengenkripsi pesan tersebut, katakan 'serang dari tenggara'. Dia akan mengatur teks biasa dan kunci numerik sebagai berikut -

  • Dia sekarang menggeser setiap alfabet teks biasa dengan nomor yang tertulis di bawahnya untuk membuat teks sandi seperti yang ditunjukkan di bawah ini -

  • Di sini, setiap karakter teks biasa telah digeser dengan jumlah yang berbeda - dan jumlah itu ditentukan oleh tombolnya. Kunci harus kurang dari atau sama dengan ukuran pesan.

  • Untuk dekripsi, penerima menggunakan kunci yang sama dan menggeser teks sandi yang diterima dalam urutan terbalik untuk mendapatkan teks biasa.

Nilai Keamanan

Vigenere Cipher dirancang dengan mengutak-atik cipher Caesar standar untuk mengurangi keefektifan kriptanalisis pada ciphertext dan membuat sistem kriptografi lebih kuat. Ini secara signifikanmore secure than a regular Caesar Cipher.

Dalam sejarah, itu secara teratur digunakan untuk melindungi informasi politik dan militer yang sensitif. Itu disebut sebagaiunbreakable cipher karena kesulitan yang ditimbulkannya pada pembacaan sandi.

Varian dari Vigenere Cipher

Ada dua kasus khusus sandi Vigenere -

  • Panjang kata kunci sama dengan pesan plaintect. Kasus ini disebutVernam Cipher. Ini lebih aman daripada sandi Vigenere biasa.

  • Sandi Vigenere menjadi sebuah kriptosistem dengan kerahasiaan sempurna, yang disebut sebagai One-time pad.

Pad Satu Kali

Keadaannya adalah -

  • Panjang kata kunci sama dengan panjang teks biasa.
  • Kata kunci adalah string huruf yang dibuat secara acak.
  • Kata kunci hanya digunakan sekali.

Nilai Keamanan

Mari kita bandingkan cipher Shift dengan pad satu kali.

Shift Cipher - Mudah Rusak

Dalam kasus cipher Shift, seluruh pesan bisa saja mengalami pergeseran antara 1 dan 25. Ini adalah ukuran yang sangat kecil, dan sangat mudah untuk menggunakan brute force. Namun, dengan setiap karakter sekarang memiliki pergeseran individualnya sendiri antara 1 dan 26, kunci yang mungkin tumbuh secara eksponensial untuk pesan tersebut.

Pad Satu Kali - Tidak Mungkin Rusak

Katakanlah, kami mengenkripsi nama "titik" dengan pad satu kali. Ini adalah teks 5 huruf. Untuk memecahkan ciphertext dengan brute force, Anda perlu mencoba semua kemungkinan kunci dan melakukan komputasi untuk (26 x 26 x 26 x 26 x 26) = 26 5 = 11881376 kali. Itu untuk pesan dengan 5 huruf. Jadi, untuk pesan yang lebih panjang, komputasi tumbuh secara eksponensial dengan setiap alfabet tambahan. Hal ini membuat komputasi tidak mungkin untuk memecahkan ciphertext dengan brute force.

Transposition Cipher

Ini adalah jenis sandi lain di mana urutan huruf dalam teks biasa diatur ulang untuk membuat teks sandi. Huruf teks biasa yang sebenarnya tidak diganti.

Contohnya adalah sandi 'transposisi kolumnar sederhana' di mana teks biasa ditulis secara horizontal dengan lebar alfabet tertentu. Kemudian ciphertext dibaca secara vertikal seperti yang ditunjukkan.

Misalnya, teks biasa adalah "patung emas ada di gua kesebelas" dan kunci acak rahasia yang dipilih adalah "lima". Kami menyusun teks ini secara horizontal dalam tabel dengan jumlah kolom sama dengan nilai kunci. Teks yang dihasilkan ditunjukkan di bawah ini.

Ciphertext diperoleh dengan membaca kolom secara vertikal ke bawah dari kolom pertama sampai terakhir. Teks sandi adalah 'gnuneaoseenvltiltedasehetivc'.

Untuk mendekripsi, penerima menyiapkan tabel serupa. Jumlah kolom sama dengan nomor kunci. Jumlah baris diperoleh dengan membagi jumlah alfabet ciphertext total dengan nilai kunci dan pembulatan hasil bagi ke nilai integer berikutnya.

Penerima kemudian menulis ciphertext yang diterima secara vertikal ke bawah dan dari kolom kiri ke kanan. Untuk memperoleh teks, ia membaca secara horizontal dari kiri ke kanan dan dari baris atas ke bawah.