SlideShare a Scribd company logo
1 of 30
Data Encryption Standard (DES) 
IF5054 Kriptografi 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Pendahuluan 
• Block cipher yang diberikan di dalam kuliah: 
1. DES 
2. 3DES 
3. GOST 
4. RC5 
6. AES 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Block cipher lainnya (tidak diajarkan, dapat dibaca 
di dalam referensi, atau dijadiakn tugas makalah): 
1. Blowfish 9. SAFER 
2. IDEA 10. Twofish 
3. LOKI 12. Serpent 
4. RC2 13. RC6 
5. FEAL 14. MARS 
6. Lucifer 15. Camellia 
7. CAST 16. 3-WAY 
8. CRAB 17. MMB, SkipJack, dll 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Stream cipher yang diberikan di dalam kuliah: 
1. RC4 
2. A5 
• Stream cipher lainnya (tidak diajarkan, dapat 
dibaca di dalam referensi): 
1. A2 
2. SEAL 
3. WAKE 
4. Crypt(1) 
5. Cellular Automaton 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
DES (Data Encryption Standard) 
• Dikembangkan di IBM pada tahun 1972. 
• Berdasarkan pada algoritma Lucifer yang 
dibuat oleh Horst Feistel. 
• Disetujui oleh National Bureau of Standard 
(NBS) setelah penilaian kekuatannya oleh 
National Security Agency (NSA) Amerika 
Serikat. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Tinjauan Umum 
• DES adalah standard, sedangkan algoritmanya 
adalah DEA (Data EncryptionAlgorithm). Kedua 
nama ini sering dikacaukan. 
• DES termasuk ke dalam kriptografi kunci-simetri 
dan tergolong jenis cipher blok. 
• DES beroperasi pada ukuran blok 64 bit. 
• Panjang kunci ekternal = 64 bit (sesuai ukuran 
blok), tetapi hanya 56 bit yang dipakai (8 bit 
paritas tidak digunakan) 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Setiap blok (plainteks atau cipherteks) 
dienkripsi dalam 16 putaran. 
• Setiap putaran menggunakan kunci internal 
berbeda. 
• Kunci internal (56-bit) dibangkitkan dari 
kunci eksternal 
• Setiap blok mengalami permutasi awal (IP), 
16 putaran enciphering, dan inversi 
permutasi awal (IP-1). (lihat Gambar 9.1) 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Plainteks 
IP 
16 kali Enciphering 
IP-1 
Cipherteks 
Gambar 9.1 Skema Global Algoritma DES 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Gambar 9.2 Algoritma Enkripsi dengan DES 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB 
P l a i n t e k s 
I P 
L 0 R 0 
f 
Å 
L R1 = L0 Å f (R0 , K1 ) 1 = R 0 
K 1 
f 
Å 
L R2 = L1 Å f (R1, K2 ) 2 = R 1 
K 2 
L R15 = L14 Å f (R14 , K15 ) 1 5 = R 1 4 
K 1 6 
R16 = L15 Å f (R15 , K16 ) L 1 6 = R 1 5 
I P - 1 
C i p h e r t e k s 
f 
Å
Pembangkitan Kunci Internal 
• Kunci internal = kunci setiap putaran 
• Ada 16 putaran, jadi ada 16 kunci internal: 
K1, K2, …, K16 
• Dibangkitkan dari kunci eksternal (64 bit) 
yang diberikan oleh pengguna. 
• Gambar 9.2 memperlihatkan proses 
pembangkitan kunci internal. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Gambar 9.2. Proses pembangkitan kunci-kunci internal DES 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB 
K u n c i e k s t e r n a l 
P e r m u t a s i 
P C - 1 
C 0 D 0 
L e f t S h i f t L e f t S h i f t 
C 1 D 1 
L e f t S h i f t L e f t S h i f t 
P e r m u t a s i 
P C - 2 K 1 
C j D j 
P e r m u t a s i 
P C - 2 K j 
  
  
L e f t S h i f t L e f t S h i f t 
C 1 6 D 1 6 
P e r m u t a s i 
P C - 2 K 1 6
Matriks permutasi kompresi PC-1: 
57 49 41 33 25 17 9 1 58 50 42 34 26 18 
10 2 59 51 43 35 27 19 11 3 60 52 44 36 
63 55 47 39 31 23 15 7 62 54 46 38 30 22 
14 6 61 53 45 37 29 21 13 5 28 20 12 4 
C0: berisi bit-bit dari K pada posisi 
57, 49, 41, 33, 25, 17, 9, 1, 58, 50, 42, 34, 26, 18 
10, 2, 59, 51, 43, 35, 27, 19, 11, 3, 60, 52, 44, 36 
D0: berisi bit-bit dari K pada posisi 
63, 55, 47, 39, 31, 23, 15, 7, 62, 54, 46, 38, 30, 22 
14, 6, 61, 53, 45, 37, 29, 21, 13, 5, 28, 20, 12, 4 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Tabel 1. Jumlah pergeseran bit pada setiap putaran 
Putaran, i Jumlah pergeseran bit 
1 1 
2 1 
3 2 
4 2 
5 2 
6 2 
7 2 
8 2 
9 1 
10 2 
11 2 
12 2 
13 2 
14 2 
15 2 
16 1 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Matriks PC-2 berikut: 
14 17 11 24 1 5 3 28 15 6 21 10 
23 19 12 4 26 8 16 7 27 20 13 2 
41 52 31 37 47 55 30 40 51 45 33 48 
44 49 39 56 34 53 46 42 50 36 29 32 
Jadi, Ki merupakan penggabungan bit-bit Ci pada posisi: 
14, 17, 11, 24, 1, 5, 3, 28, 15, 6, 21, 10 
23, 19, 12, 4, 26, 8, 16, 7, 27, 20, 13, 2 
dengan bit-bit Di pada posisi: 
41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48 
44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32 
Setiap kunci internal Ki mempunyai panjang 48 bit. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Permutasi Awal 
• Tujuan: mengacak plainteks sehingga 
urutan bit-bit di dalamnya berubah. 
• Matriks permutasi awal (IP): 
58 50 42 34 26 18 10 2 60 52 44 36 28 20 12 4 
62 54 46 38 30 22 14 6 64 56 48 40 32 24 16 8 
57 49 41 33 25 17 9 1 59 51 43 35 27 19 11 3 
61 53 45 37 29 21 13 5 63 55 47 39 31 23 15 7 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Enciphering 
• Setiap blok plainteks mengalami 16 kali putaran 
enciphering . 
• Setiap putaran enciphering merupakan jaringan Feistel: 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB 
Li = Ri – 1 
Ri = Li – 1 Å f(Ri – 1, Ki) 
L Ri-1 i - 1 
f 
Å 
L Ri i 
K i
• Diagram komputasi fungsi f : 
E k s p a n s i m e n j a d i 4 8 b i t 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB 
R i - 1 
3 2 b i t 
E ( R i - 1 ) 
4 8 b i t 
Å K i 
4 8 b i t 
E(Ri-1 )Å Ki = A 
S 1 S 8 . . . 
B 
M a t r i k s s u b s t i t u s i 
4 8 b i t 
3 2 b i t 
P ( B ) 
3 2 b i t
• E adalah fungsi ekspansi yang memperluas 
blok Ri – 1 32-bit menjadi blok 48 bit. 
• Fungsi ekspansi direalisasikan dengan 
matriks permutasi ekspansi: 
32 1 2 3 4 5 4 5 6 7 8 9 
8 9 10 11 12 13 12 13 14 15 16 17 
16 17 18 19 20 21 20 21 22 23 24 25 
24 25 26 27 28 29 28 29 30 31 32 1 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Hasil ekpansi, yaitu E(Ri – 1) di-XOR-kan dengan Ki 
menghasilkan vektor A 48-bit: 
E(Ri – 1) Å Ki = A 
• Vektor A dikelompokkan menjadi 8 kelompok, 
masing-masing 6 bit, dan menjadi masukan bagi 
proses substitusi. 
• Ada 8 matriks substitusi, masing-masing 
dinyatakan dengan kotak-S. 
• Kotak –S menerima masukan 6 bit dan 
memebrikan keluaran 4 bit. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
S1: 
14 4 13 1 2 15 11 8 3 10 6 12 5 9 0 7 
0 15 7 4 14 2 13 1 10 6 12 11 9 5 3 8 
4 1 14 8 13 6 2 11 15 12 9 7 3 10 5 0 
15 12 8 2 4 9 1 7 5 11 3 14 10 0 6 13 
S2: 
15 1 8 14 6 11 3 4 9 7 2 13 12 0 5 10 
3 13 4 7 15 2 8 14 12 0 1 10 6 9 11 5 
0 14 7 11 10 4 13 1 5 8 12 6 9 3 2 15 
13 8 10 1 3 15 4 2 11 6 7 12 0 5 14 9 
S3: 
10 0 9 14 6 3 15 5 1 13 12 7 11 4 2 8 
13 7 0 9 3 4 6 10 2 8 5 14 12 11 15 1 
13 6 4 9 8 15 3 0 11 1 2 12 5 10 14 7 
1 10 13 0 6 9 8 7 4 15 14 3 11 5 2 12 
S4: 
7 13 14 3 0 6 9 10 1 2 8 5 11 12 4 15 
13 8 11 5 6 15 0 3 4 7 2 12 1 10 14 9 
10 6 9 0 12 11 7 13 15 1 3 14 5 2 8 4 
3 15 0 6 10 1 13 8 9 4 5 11 12 7 2 14 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
S5: 
2 12 4 1 7 10 11 6 8 5 3 15 13 0 14 9 
14 11 2 12 4 7 13 1 5 0 15 10 3 9 8 16 
4 2 1 11 10 13 7 8 15 9 12 5 6 3 0 14 
11 8 12 7 1 14 2 13 6 15 0 9 10 4 5 3 
S6: 
12 1 10 15 9 2 6 8 0 13 3 4 14 7 5 11 
10 15 4 2 7 12 9 5 6 1 13 14 0 11 3 8 
9 14 15 5 2 8 12 3 7 0 4 10 1 13 11 6 
4 3 2 12 9 5 15 10 11 14 1 7 6 0 8 13 
S7: 
4 11 2 14 15 0 8 13 3 12 9 7 5 10 6 1 
13 0 11 7 4 9 1 10 14 3 5 12 2 15 8 6 
1 4 11 13 12 3 7 14 10 15 6 8 0 5 9 2 
6 11 13 8 1 4 10 7 9 5 0 15 14 2 3 12 
S8: 
13 2 8 4 6 15 11 1 10 9 3 14 5 0 12 7 
1 15 13 8 10 3 7 4 12 5 6 11 0 14 9 2 
7 11 4 1 9 12 14 2 0 6 10 13 15 3 5 8 
2 1 14 7 4 10 8 13 15 12 9 0 3 5 6 11 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Keluaran proses substitusi adalah vektor B yang 
panjangnya 48 bit. 
• Vektor B menjadi masukan untuk proses 
permutasi. 
• Tujuan permutasi adalah untuk mengacak hasil 
proses substitusi kotak-S. 
• Permutasi dilakukan dengan menggunakan 
matriks permutasi P (P-box) sbb: 
16 7 20 21 29 12 28 17 1 15 23 26 5 8 31 10 
2 8 24 14 32 27 3 9 19 13 30 6 22 11 4 25 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• P(B) merupakan keluaran dari fungsi f. 
• Bit-bit P(B) di-XOR-kan dengan Li – 1 menghasilkan Ri: 
Ri = Li – 1 Å P(B) 
• Jadi, keluaran dari putaran ke-i adalah 
(Li, Ri) = (Ri – 1 , Li – 1 Å P(B)) 
f 
Å 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB 
L i - 1 
R i 
3 2 b i t 
3 2 b i t
Inversi Permutasi (IP-1) 
• Permutasi terakhir dilakukan setelah 16 kali 
putaran terhadap gabungan blok kiri dan blok 
kanan. 
• Permutasi menggunakan matriks permutasi awal 
balikan (IP-1 ) sbb: 
40 8 48 16 56 24 64 32 39 7 47 15 55 23 63 31 
38 6 46 14 54 22 62 30 37 5 45 13 53 21 61 29 
36 4 44 12 52 20 60 28 35 3 43 11 51 19 59 27 
34 2 42 10 50 18 58 26 33 1 41 9 49 17 57 25 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Dekripsi 
• Dekripsi terhadap cipherteks merupakan kebalikan 
dari proses enkripsi. 
• DES menggunakan algoritma yang sama untuk 
proses enkripsi dan dekripsi. 
• Pada proses dekripsi urutan kunci yang digunakan 
adalah K16, K15, …, K1. 
• Untuk tiap putaran 16, 15, …, 1, keluaran pada 
setiap putaran deciphering adalah 
Li = Ri – 1 
Ri = Li – 1 Å f(Ri – 1, Ki) 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Mode DES 
• DES dapat dioperasikan dengan mode ECB, 
CBC, OFB, dan CFB. 
• Namun karena kesederhanaannya, mode 
ECB lebih sering digunakan pada paket 
komersil. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Implementasi DES 
• DES sudah diimplementasikan dalam bentuk 
perangkat keras. 
• Dalam bentuk perangkat keras, DES 
diimplementasikan di dalam chip. Setiap detik 
chip ini dapat mengenkripsikan 16,8 juta blok 
(atau 1 gigabit per detik). 
• Implementasi DES ke dalam perangkat lunak 
dapat melakukan enkripsi 32.000 blok per detik 
(pada komputer mainframe IBM 3090). 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
Keamanan DES 
• Keamanan DES ditentukan oleh kunci. 
• Panjang kunci eksternal DES hanya 64 bit, tetapi yang 
dipakai hanya 56 bit. 
• Pada rancangan awal, panjang kunci yang diusulkan IBM 
adalah 128 bit, tetapi atas permintaan NSA, panjang kunci 
diperkecil menjadi 56 bit. 
• Tetapi, dengan panjang kunci 56 bit akan terdapat 256 atau 
72.057.594.037.927.936 kemungkinan kunci. 
• Jika serangan exhaustive key search dengan menggunakan 
prosesor paralel, maka dalam satu detik dapat dikerjakan 
satu juta serangan. Jadi seluruhnya diperlukan 1142 tahun 
untuk menemukan kunci yang benar. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Tahun 1998, Electronic Frontier Foundation 
(EFE) merancang dan membuat perangkat keras 
khusus untuk menemukan kunci DES secara 
exhaustive search key dengan biaya $250.000 dan 
diharapkan dapat menemukan kunci selama 5 hari. 
• Tahun 1999, kombinasi perangkat keras EFE 
dengan kolaborasi internet yang melibatkan lebih 
dari 100.000 komputer dapat menemukan kunci 
DES kurang dari 1 hari. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB
• Pengisian kotak-S DES masih menjadi misteri. 
• Delapan putaran sudah cukup untuk membuat 
cipherteks sebagai fungsi acak dari setiap bit 
plainteks dan setiap bit cipherteks. 
• Dari penelitian, DES dengan jumlah putaran yang 
kurang dari 16 ternyata dapat dipecahkan dengan 
known-plaintext attack. 
IF5054/Rinaldi Munir/Prodi IF/STEI ITB

More Related Content

More from Universitas Bina Darma Palembang

More from Universitas Bina Darma Palembang (20)

30448 pertemuan1
30448 pertemuan130448 pertemuan1
30448 pertemuan1
 
29510 pertemuan18(form method-get-post-dan-session(1))
29510 pertemuan18(form method-get-post-dan-session(1))29510 pertemuan18(form method-get-post-dan-session(1))
29510 pertemuan18(form method-get-post-dan-session(1))
 
28501 pertemuan14(php)
28501 pertemuan14(php)28501 pertemuan14(php)
28501 pertemuan14(php)
 
28500 pertemuan22(header dokumen html dgn tag title)
28500 pertemuan22(header dokumen html dgn tag title)28500 pertemuan22(header dokumen html dgn tag title)
28500 pertemuan22(header dokumen html dgn tag title)
 
25437 pertemuan25(hitcounter)
25437 pertemuan25(hitcounter)25437 pertemuan25(hitcounter)
25437 pertemuan25(hitcounter)
 
23921 pertemuan 3
23921 pertemuan 323921 pertemuan 3
23921 pertemuan 3
 
19313 pertemuan6
19313 pertemuan619313 pertemuan6
19313 pertemuan6
 
18759 pertemuan20(web html editor)
18759 pertemuan20(web html editor)18759 pertemuan20(web html editor)
18759 pertemuan20(web html editor)
 
18040 pertemuan13(css)
18040 pertemuan13(css)18040 pertemuan13(css)
18040 pertemuan13(css)
 
17945 pertemuan5
17945 pertemuan517945 pertemuan5
17945 pertemuan5
 
16406 pertemuan17(konsep basis-data-di-web)
16406 pertemuan17(konsep basis-data-di-web)16406 pertemuan17(konsep basis-data-di-web)
16406 pertemuan17(konsep basis-data-di-web)
 
15294 pertemuan9(eksplorasi &defenisi masalah0
15294 pertemuan9(eksplorasi &defenisi masalah015294 pertemuan9(eksplorasi &defenisi masalah0
15294 pertemuan9(eksplorasi &defenisi masalah0
 
13926 pertemuan4
13926 pertemuan413926 pertemuan4
13926 pertemuan4
 
12738 pertemuan 15(php lanjutan)
12738 pertemuan 15(php lanjutan)12738 pertemuan 15(php lanjutan)
12738 pertemuan 15(php lanjutan)
 
6346 pertemuan21(web statis dengan struktur html)
6346 pertemuan21(web statis dengan struktur html)6346 pertemuan21(web statis dengan struktur html)
6346 pertemuan21(web statis dengan struktur html)
 
5623 pertemuan11(html1)
5623 pertemuan11(html1)5623 pertemuan11(html1)
5623 pertemuan11(html1)
 
4740 pertemuan8(komponen dalam web)
4740 pertemuan8(komponen dalam web)4740 pertemuan8(komponen dalam web)
4740 pertemuan8(komponen dalam web)
 
4075 pertemuan10 (analisa kebutuhan)
4075 pertemuan10 (analisa kebutuhan)4075 pertemuan10 (analisa kebutuhan)
4075 pertemuan10 (analisa kebutuhan)
 
2670 pertemuan12(html lanjut)
2670 pertemuan12(html lanjut)2670 pertemuan12(html lanjut)
2670 pertemuan12(html lanjut)
 
2190 pertemuan24(polling)
2190 pertemuan24(polling)2190 pertemuan24(polling)
2190 pertemuan24(polling)
 

Recently uploaded

Perencanaan Pelabuhan perikanan id.pptx
Perencanaan Pelabuhan perikanan  id.pptxPerencanaan Pelabuhan perikanan  id.pptx
Perencanaan Pelabuhan perikanan id.pptxNadhifMuhammad5
 
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.ppt
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.pptTUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.ppt
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.pptOloy2
 
Pengukuran Topografi menggunakan GPS Geodetik
Pengukuran Topografi menggunakan GPS GeodetikPengukuran Topografi menggunakan GPS Geodetik
Pengukuran Topografi menggunakan GPS Geodetikzulmushawir2
 
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptx
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptxPetunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptx
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptxpkmcipakudrive
 
tugas pelaksana lapangan pekerjaan saluran irigasi
tugas pelaksana lapangan pekerjaan saluran irigasitugas pelaksana lapangan pekerjaan saluran irigasi
tugas pelaksana lapangan pekerjaan saluran irigasifrenkytanzil5
 
metode pengukuran waktu secaratidak langsung
metode pengukuran waktu secaratidak langsungmetode pengukuran waktu secaratidak langsung
metode pengukuran waktu secaratidak langsungssuser4cf36c
 
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptx
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptxPROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptx
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptxadista7
 
UJI KOMPETENSI-Presentasi Bidang Jalan.pptx
UJI KOMPETENSI-Presentasi Bidang Jalan.pptxUJI KOMPETENSI-Presentasi Bidang Jalan.pptx
UJI KOMPETENSI-Presentasi Bidang Jalan.pptxnuhungbintoking
 
Metode_Sampling bahan galian mineral.pptx
Metode_Sampling bahan galian mineral.pptxMetode_Sampling bahan galian mineral.pptx
Metode_Sampling bahan galian mineral.pptxHeriGeologist
 
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptxarisvanrush
 

Recently uploaded (18)

Perencanaan Pelabuhan perikanan id.pptx
Perencanaan Pelabuhan perikanan  id.pptxPerencanaan Pelabuhan perikanan  id.pptx
Perencanaan Pelabuhan perikanan id.pptx
 
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.ppt
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.pptTUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.ppt
TUGAS PPT APRIZAL GEDUNG44yddafhhhhhhhhhhhhhhhh.ppt
 
Pengukuran Topografi menggunakan GPS Geodetik
Pengukuran Topografi menggunakan GPS GeodetikPengukuran Topografi menggunakan GPS Geodetik
Pengukuran Topografi menggunakan GPS Geodetik
 
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptx
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptxPetunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptx
Petunjuk teknis Pengisian Usulan Alat Kesehatan SOPHI.pptx
 
tugas pelaksana lapangan pekerjaan saluran irigasi
tugas pelaksana lapangan pekerjaan saluran irigasitugas pelaksana lapangan pekerjaan saluran irigasi
tugas pelaksana lapangan pekerjaan saluran irigasi
 
metode pengukuran waktu secaratidak langsung
metode pengukuran waktu secaratidak langsungmetode pengukuran waktu secaratidak langsung
metode pengukuran waktu secaratidak langsung
 
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptx
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptxPROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptx
PROSEDUR DALAM MELAKUKAN PERHITUNGAN PEKERJAAN PINTU.pptx
 
UJI KOMPETENSI-Presentasi Bidang Jalan.pptx
UJI KOMPETENSI-Presentasi Bidang Jalan.pptxUJI KOMPETENSI-Presentasi Bidang Jalan.pptx
UJI KOMPETENSI-Presentasi Bidang Jalan.pptx
 
Metode_Sampling bahan galian mineral.pptx
Metode_Sampling bahan galian mineral.pptxMetode_Sampling bahan galian mineral.pptx
Metode_Sampling bahan galian mineral.pptx
 
obat aborsi Pangkal pinang Wa 082223109953 Jual obat aborsi Cytotec asli Di P...
obat aborsi Pangkal pinang Wa 082223109953 Jual obat aborsi Cytotec asli Di P...obat aborsi Pangkal pinang Wa 082223109953 Jual obat aborsi Cytotec asli Di P...
obat aborsi Pangkal pinang Wa 082223109953 Jual obat aborsi Cytotec asli Di P...
 
Jual Obat Aborsi Samarinda ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jua...
Jual Obat Aborsi Samarinda ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jua...Jual Obat Aborsi Samarinda ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jua...
Jual Obat Aborsi Samarinda ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jua...
 
Jual Obat Aborsi Denpasar Bali ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik...
Jual Obat Aborsi Denpasar Bali ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik...Jual Obat Aborsi Denpasar Bali ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik...
Jual Obat Aborsi Denpasar Bali ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik...
 
Klinik Obat Aborsi Di Depok Wa 082223109953 Klinik Aborsi Di Depok
Klinik Obat Aborsi Di Depok Wa 082223109953 Klinik Aborsi Di DepokKlinik Obat Aborsi Di Depok Wa 082223109953 Klinik Aborsi Di Depok
Klinik Obat Aborsi Di Depok Wa 082223109953 Klinik Aborsi Di Depok
 
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx
703618627-PPT-INVESTIGASI-KECELAKAAN-KERJA.pptx
 
Jual Obat Aborsi Batam ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jual Ob...
Jual Obat Aborsi Batam ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jual Ob...Jual Obat Aborsi Batam ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jual Ob...
Jual Obat Aborsi Batam ( Asli Ampuh No.1 ) 082223109953 Tempat Klinik Jual Ob...
 
Obat Aborsi Sungai Penuh 082223109953 Jual Cytotec Asli Di Sungai Penuh
Obat Aborsi Sungai Penuh 082223109953 Jual Cytotec Asli Di Sungai PenuhObat Aborsi Sungai Penuh 082223109953 Jual Cytotec Asli Di Sungai Penuh
Obat Aborsi Sungai Penuh 082223109953 Jual Cytotec Asli Di Sungai Penuh
 
Jual Obat Aborsi Jakarta Selatan 0822 2310 9953 Klinik Jual Obat Cytotec Asli...
Jual Obat Aborsi Jakarta Selatan 0822 2310 9953 Klinik Jual Obat Cytotec Asli...Jual Obat Aborsi Jakarta Selatan 0822 2310 9953 Klinik Jual Obat Cytotec Asli...
Jual Obat Aborsi Jakarta Selatan 0822 2310 9953 Klinik Jual Obat Cytotec Asli...
 
Obat Aborsi jakarta WA 082223109953 Jual Obat Aborsi Cytotec Asli Di jakarta
Obat Aborsi jakarta WA 082223109953  Jual Obat Aborsi Cytotec Asli Di jakartaObat Aborsi jakarta WA 082223109953  Jual Obat Aborsi Cytotec Asli Di jakarta
Obat Aborsi jakarta WA 082223109953 Jual Obat Aborsi Cytotec Asli Di jakarta
 

16.data encryption standard (des)

  • 1. Data Encryption Standard (DES) IF5054 Kriptografi IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 2. Pendahuluan • Block cipher yang diberikan di dalam kuliah: 1. DES 2. 3DES 3. GOST 4. RC5 6. AES IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 3. • Block cipher lainnya (tidak diajarkan, dapat dibaca di dalam referensi, atau dijadiakn tugas makalah): 1. Blowfish 9. SAFER 2. IDEA 10. Twofish 3. LOKI 12. Serpent 4. RC2 13. RC6 5. FEAL 14. MARS 6. Lucifer 15. Camellia 7. CAST 16. 3-WAY 8. CRAB 17. MMB, SkipJack, dll IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 4. • Stream cipher yang diberikan di dalam kuliah: 1. RC4 2. A5 • Stream cipher lainnya (tidak diajarkan, dapat dibaca di dalam referensi): 1. A2 2. SEAL 3. WAKE 4. Crypt(1) 5. Cellular Automaton IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 5. DES (Data Encryption Standard) • Dikembangkan di IBM pada tahun 1972. • Berdasarkan pada algoritma Lucifer yang dibuat oleh Horst Feistel. • Disetujui oleh National Bureau of Standard (NBS) setelah penilaian kekuatannya oleh National Security Agency (NSA) Amerika Serikat. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 6. Tinjauan Umum • DES adalah standard, sedangkan algoritmanya adalah DEA (Data EncryptionAlgorithm). Kedua nama ini sering dikacaukan. • DES termasuk ke dalam kriptografi kunci-simetri dan tergolong jenis cipher blok. • DES beroperasi pada ukuran blok 64 bit. • Panjang kunci ekternal = 64 bit (sesuai ukuran blok), tetapi hanya 56 bit yang dipakai (8 bit paritas tidak digunakan) IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 7. • Setiap blok (plainteks atau cipherteks) dienkripsi dalam 16 putaran. • Setiap putaran menggunakan kunci internal berbeda. • Kunci internal (56-bit) dibangkitkan dari kunci eksternal • Setiap blok mengalami permutasi awal (IP), 16 putaran enciphering, dan inversi permutasi awal (IP-1). (lihat Gambar 9.1) IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 8. Plainteks IP 16 kali Enciphering IP-1 Cipherteks Gambar 9.1 Skema Global Algoritma DES IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 9. Gambar 9.2 Algoritma Enkripsi dengan DES IF5054/Rinaldi Munir/Prodi IF/STEI ITB P l a i n t e k s I P L 0 R 0 f Å L R1 = L0 Å f (R0 , K1 ) 1 = R 0 K 1 f Å L R2 = L1 Å f (R1, K2 ) 2 = R 1 K 2 L R15 = L14 Å f (R14 , K15 ) 1 5 = R 1 4 K 1 6 R16 = L15 Å f (R15 , K16 ) L 1 6 = R 1 5 I P - 1 C i p h e r t e k s f Å
  • 10. Pembangkitan Kunci Internal • Kunci internal = kunci setiap putaran • Ada 16 putaran, jadi ada 16 kunci internal: K1, K2, …, K16 • Dibangkitkan dari kunci eksternal (64 bit) yang diberikan oleh pengguna. • Gambar 9.2 memperlihatkan proses pembangkitan kunci internal. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 11. Gambar 9.2. Proses pembangkitan kunci-kunci internal DES IF5054/Rinaldi Munir/Prodi IF/STEI ITB K u n c i e k s t e r n a l P e r m u t a s i P C - 1 C 0 D 0 L e f t S h i f t L e f t S h i f t C 1 D 1 L e f t S h i f t L e f t S h i f t P e r m u t a s i P C - 2 K 1 C j D j P e r m u t a s i P C - 2 K j     L e f t S h i f t L e f t S h i f t C 1 6 D 1 6 P e r m u t a s i P C - 2 K 1 6
  • 12. Matriks permutasi kompresi PC-1: 57 49 41 33 25 17 9 1 58 50 42 34 26 18 10 2 59 51 43 35 27 19 11 3 60 52 44 36 63 55 47 39 31 23 15 7 62 54 46 38 30 22 14 6 61 53 45 37 29 21 13 5 28 20 12 4 C0: berisi bit-bit dari K pada posisi 57, 49, 41, 33, 25, 17, 9, 1, 58, 50, 42, 34, 26, 18 10, 2, 59, 51, 43, 35, 27, 19, 11, 3, 60, 52, 44, 36 D0: berisi bit-bit dari K pada posisi 63, 55, 47, 39, 31, 23, 15, 7, 62, 54, 46, 38, 30, 22 14, 6, 61, 53, 45, 37, 29, 21, 13, 5, 28, 20, 12, 4 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 13. Tabel 1. Jumlah pergeseran bit pada setiap putaran Putaran, i Jumlah pergeseran bit 1 1 2 1 3 2 4 2 5 2 6 2 7 2 8 2 9 1 10 2 11 2 12 2 13 2 14 2 15 2 16 1 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 14. Matriks PC-2 berikut: 14 17 11 24 1 5 3 28 15 6 21 10 23 19 12 4 26 8 16 7 27 20 13 2 41 52 31 37 47 55 30 40 51 45 33 48 44 49 39 56 34 53 46 42 50 36 29 32 Jadi, Ki merupakan penggabungan bit-bit Ci pada posisi: 14, 17, 11, 24, 1, 5, 3, 28, 15, 6, 21, 10 23, 19, 12, 4, 26, 8, 16, 7, 27, 20, 13, 2 dengan bit-bit Di pada posisi: 41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48 44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32 Setiap kunci internal Ki mempunyai panjang 48 bit. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 15. Permutasi Awal • Tujuan: mengacak plainteks sehingga urutan bit-bit di dalamnya berubah. • Matriks permutasi awal (IP): 58 50 42 34 26 18 10 2 60 52 44 36 28 20 12 4 62 54 46 38 30 22 14 6 64 56 48 40 32 24 16 8 57 49 41 33 25 17 9 1 59 51 43 35 27 19 11 3 61 53 45 37 29 21 13 5 63 55 47 39 31 23 15 7 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 16. Enciphering • Setiap blok plainteks mengalami 16 kali putaran enciphering . • Setiap putaran enciphering merupakan jaringan Feistel: IF5054/Rinaldi Munir/Prodi IF/STEI ITB Li = Ri – 1 Ri = Li – 1 Å f(Ri – 1, Ki) L Ri-1 i - 1 f Å L Ri i K i
  • 17. • Diagram komputasi fungsi f : E k s p a n s i m e n j a d i 4 8 b i t IF5054/Rinaldi Munir/Prodi IF/STEI ITB R i - 1 3 2 b i t E ( R i - 1 ) 4 8 b i t Å K i 4 8 b i t E(Ri-1 )Å Ki = A S 1 S 8 . . . B M a t r i k s s u b s t i t u s i 4 8 b i t 3 2 b i t P ( B ) 3 2 b i t
  • 18. • E adalah fungsi ekspansi yang memperluas blok Ri – 1 32-bit menjadi blok 48 bit. • Fungsi ekspansi direalisasikan dengan matriks permutasi ekspansi: 32 1 2 3 4 5 4 5 6 7 8 9 8 9 10 11 12 13 12 13 14 15 16 17 16 17 18 19 20 21 20 21 22 23 24 25 24 25 26 27 28 29 28 29 30 31 32 1 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 19. • Hasil ekpansi, yaitu E(Ri – 1) di-XOR-kan dengan Ki menghasilkan vektor A 48-bit: E(Ri – 1) Å Ki = A • Vektor A dikelompokkan menjadi 8 kelompok, masing-masing 6 bit, dan menjadi masukan bagi proses substitusi. • Ada 8 matriks substitusi, masing-masing dinyatakan dengan kotak-S. • Kotak –S menerima masukan 6 bit dan memebrikan keluaran 4 bit. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 20. S1: 14 4 13 1 2 15 11 8 3 10 6 12 5 9 0 7 0 15 7 4 14 2 13 1 10 6 12 11 9 5 3 8 4 1 14 8 13 6 2 11 15 12 9 7 3 10 5 0 15 12 8 2 4 9 1 7 5 11 3 14 10 0 6 13 S2: 15 1 8 14 6 11 3 4 9 7 2 13 12 0 5 10 3 13 4 7 15 2 8 14 12 0 1 10 6 9 11 5 0 14 7 11 10 4 13 1 5 8 12 6 9 3 2 15 13 8 10 1 3 15 4 2 11 6 7 12 0 5 14 9 S3: 10 0 9 14 6 3 15 5 1 13 12 7 11 4 2 8 13 7 0 9 3 4 6 10 2 8 5 14 12 11 15 1 13 6 4 9 8 15 3 0 11 1 2 12 5 10 14 7 1 10 13 0 6 9 8 7 4 15 14 3 11 5 2 12 S4: 7 13 14 3 0 6 9 10 1 2 8 5 11 12 4 15 13 8 11 5 6 15 0 3 4 7 2 12 1 10 14 9 10 6 9 0 12 11 7 13 15 1 3 14 5 2 8 4 3 15 0 6 10 1 13 8 9 4 5 11 12 7 2 14 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 21. S5: 2 12 4 1 7 10 11 6 8 5 3 15 13 0 14 9 14 11 2 12 4 7 13 1 5 0 15 10 3 9 8 16 4 2 1 11 10 13 7 8 15 9 12 5 6 3 0 14 11 8 12 7 1 14 2 13 6 15 0 9 10 4 5 3 S6: 12 1 10 15 9 2 6 8 0 13 3 4 14 7 5 11 10 15 4 2 7 12 9 5 6 1 13 14 0 11 3 8 9 14 15 5 2 8 12 3 7 0 4 10 1 13 11 6 4 3 2 12 9 5 15 10 11 14 1 7 6 0 8 13 S7: 4 11 2 14 15 0 8 13 3 12 9 7 5 10 6 1 13 0 11 7 4 9 1 10 14 3 5 12 2 15 8 6 1 4 11 13 12 3 7 14 10 15 6 8 0 5 9 2 6 11 13 8 1 4 10 7 9 5 0 15 14 2 3 12 S8: 13 2 8 4 6 15 11 1 10 9 3 14 5 0 12 7 1 15 13 8 10 3 7 4 12 5 6 11 0 14 9 2 7 11 4 1 9 12 14 2 0 6 10 13 15 3 5 8 2 1 14 7 4 10 8 13 15 12 9 0 3 5 6 11 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 22. • Keluaran proses substitusi adalah vektor B yang panjangnya 48 bit. • Vektor B menjadi masukan untuk proses permutasi. • Tujuan permutasi adalah untuk mengacak hasil proses substitusi kotak-S. • Permutasi dilakukan dengan menggunakan matriks permutasi P (P-box) sbb: 16 7 20 21 29 12 28 17 1 15 23 26 5 8 31 10 2 8 24 14 32 27 3 9 19 13 30 6 22 11 4 25 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 23. • P(B) merupakan keluaran dari fungsi f. • Bit-bit P(B) di-XOR-kan dengan Li – 1 menghasilkan Ri: Ri = Li – 1 Å P(B) • Jadi, keluaran dari putaran ke-i adalah (Li, Ri) = (Ri – 1 , Li – 1 Å P(B)) f Å IF5054/Rinaldi Munir/Prodi IF/STEI ITB L i - 1 R i 3 2 b i t 3 2 b i t
  • 24. Inversi Permutasi (IP-1) • Permutasi terakhir dilakukan setelah 16 kali putaran terhadap gabungan blok kiri dan blok kanan. • Permutasi menggunakan matriks permutasi awal balikan (IP-1 ) sbb: 40 8 48 16 56 24 64 32 39 7 47 15 55 23 63 31 38 6 46 14 54 22 62 30 37 5 45 13 53 21 61 29 36 4 44 12 52 20 60 28 35 3 43 11 51 19 59 27 34 2 42 10 50 18 58 26 33 1 41 9 49 17 57 25 IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 25. Dekripsi • Dekripsi terhadap cipherteks merupakan kebalikan dari proses enkripsi. • DES menggunakan algoritma yang sama untuk proses enkripsi dan dekripsi. • Pada proses dekripsi urutan kunci yang digunakan adalah K16, K15, …, K1. • Untuk tiap putaran 16, 15, …, 1, keluaran pada setiap putaran deciphering adalah Li = Ri – 1 Ri = Li – 1 Å f(Ri – 1, Ki) IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 26. Mode DES • DES dapat dioperasikan dengan mode ECB, CBC, OFB, dan CFB. • Namun karena kesederhanaannya, mode ECB lebih sering digunakan pada paket komersil. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 27. Implementasi DES • DES sudah diimplementasikan dalam bentuk perangkat keras. • Dalam bentuk perangkat keras, DES diimplementasikan di dalam chip. Setiap detik chip ini dapat mengenkripsikan 16,8 juta blok (atau 1 gigabit per detik). • Implementasi DES ke dalam perangkat lunak dapat melakukan enkripsi 32.000 blok per detik (pada komputer mainframe IBM 3090). IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 28. Keamanan DES • Keamanan DES ditentukan oleh kunci. • Panjang kunci eksternal DES hanya 64 bit, tetapi yang dipakai hanya 56 bit. • Pada rancangan awal, panjang kunci yang diusulkan IBM adalah 128 bit, tetapi atas permintaan NSA, panjang kunci diperkecil menjadi 56 bit. • Tetapi, dengan panjang kunci 56 bit akan terdapat 256 atau 72.057.594.037.927.936 kemungkinan kunci. • Jika serangan exhaustive key search dengan menggunakan prosesor paralel, maka dalam satu detik dapat dikerjakan satu juta serangan. Jadi seluruhnya diperlukan 1142 tahun untuk menemukan kunci yang benar. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 29. • Tahun 1998, Electronic Frontier Foundation (EFE) merancang dan membuat perangkat keras khusus untuk menemukan kunci DES secara exhaustive search key dengan biaya $250.000 dan diharapkan dapat menemukan kunci selama 5 hari. • Tahun 1999, kombinasi perangkat keras EFE dengan kolaborasi internet yang melibatkan lebih dari 100.000 komputer dapat menemukan kunci DES kurang dari 1 hari. IF5054/Rinaldi Munir/Prodi IF/STEI ITB
  • 30. • Pengisian kotak-S DES masih menjadi misteri. • Delapan putaran sudah cukup untuk membuat cipherteks sebagai fungsi acak dari setiap bit plainteks dan setiap bit cipherteks. • Dari penelitian, DES dengan jumlah putaran yang kurang dari 16 ternyata dapat dipecahkan dengan known-plaintext attack. IF5054/Rinaldi Munir/Prodi IF/STEI ITB