TUGAS AKHIR SM 141501
PENGAMAN PENGIRIMAN PESAN VIA SMS DENGAN ALGORITMA RSA BERBASIS ANDROID ANDI RISKI ALVIANTO NRP 1210 100 040 Dosen Pembimbing Dr. Darmaji, S.Si, MT Jurusan Matematika Fakultas Matematika dan Ilmu Pengetahuan Alam Institut Teknologi Sepuluh Nopember Surabaya 2014
FINAL PROJECT SM 141501
SECURITY OF MESSAGES VIA SMS BY USING RSA ALGORITHM BASED ON ANDROID ANDI RISKI ALVIANTO NRP 1210 100 040 Supervisor Dr. Darmaji, S.Si, MT Department Of Mathematics Faculty Of Mathematics and Sciences Sepuluh Nopember Institute Of Technology Surabaya 2015
LEMBAR PENGESAHAN PENGAMAN PENGIRIMAN PESAN VIA SMS DENGAN ALGORITMA RSA BERBASIS ANDROID SECURITY OF MESSAGES VIA SMS BY USING RSA ALGORITHM BASED ON ANDROID TUGAS AKHIR Diajukan untuk memenuhi salah satu syarat Memperoleh gelar Sarjana Sains Pada bidang studi Ilmu Komputer Program Studi S-1 Jurusan Matematika Fakultas Matematika dan Ilmu Pengetahuan Alam Institut Teknologi Sepuluh Nopember Surabaya Oleh : ANDI RISKI ALVIANTO NRP. 1210 100 040 Menyetujui, Dosen Pembimbing, Dr. Darmaji, S.Si, MT NIP. 19691015 199412 1 001 Mengetahui, Ketua Jurusan Matematika FMIPA ITS Prof. Dr. Erna Apriliani, M.Si NIP. 19660414 199102 2 001 Surabaya, 2 Februari 2015
v
”Halaman ini sengaja dikosongkan”
vi
PENGAMAN PENGIRIMAN PESAN VIA SMS DENGAN ALGORITMA RSA BERBASIS ANDROID Nama NRP Jurusan Dosen Pembimbing
: Andi Riski Alvianto : 1210 100 040 : Matematika FMIPA – ITS : Dr. Darmaji, S.Si, MT
Abstrak Saat ini penggunaan Smartphone sangat digemari oleh banyak kalangan, khususnya Smartphone berbasis Android. Mulai dari kalangan masyarakat bawah hingga kalangan atas. Salah satu fitur Smartphone yang juga banyak diminati oleh masyarakat adalah SMS. SMS adalah salah satu fitur yang banyak digunakan dan dimanfaatkan oleh masyarakat, namun ada satu masalah yang sering dihadapi oleh masyarakat dalam menggunakan SMS yaitu masalah keamanan pesan SMS. Kriptografi merupakan salah satu solusi yang dapat dimanfaatkan dan dikembangkan dalam menyelesaikan permasalahan keamanan pesan SMS. Dengan melakukan enkripsi pada pesan SMS, maka kemanan pesan SMS akan lebih terjaga dan aman. Kriptografi memiliki banyak teknik dalam melakukan pengenkripsian pesan SMS dan salah satu yang memiliki tingkat keamanan yang tinggi dan tingkat kesulitan dalam pemecahannya adalah algoritma RSA. Sehingga orang atau pihak yang tidak bertanggung jawab akan mengalami kesulitan dalam melakukan tindakannya. Pada tugas akhir ini, penulis mengembangkan sebuah aplikasi pada smartphone berbasis Android untuk memodifikasi pesan SMS menjadi ciphertext agar isi informasi dari SMS tersebut tidak diketahui oleh orang lain. Untuk pengiriman SMS sistem mengenkripsi pesan menjadi ciphertext kemudian mengirimkan ke nomor tujuan. Untuk penerimaan SMS sistem mendekripsi ciphertext
vii
menjadi plaintext menggunakan key yang diinputkan oleh penerima kemudian menampilkan pesan asli kepada penerima. Aplikasi ini dapat dimanfaatkan oleh seseorang yang ingin mengirimkan suatu informasi rahasia kepada orang lain melalui SMS tanpa takut informasi dari pesan tersebut akan diketahui oleh orang lain. Metode yang digunakan dalam mengenkripsi dan mendekripsi pesan adalah algoritma RSA dan implementasinya menggunakan Eclipse IDE. Kata kunci : Smartphone, Android, SMS, kriptografi, enkripsi, dekripsi, RSA
viii
SECURITY OF MESSAGES VIA SMS BY USING RSA ALGORITHM BASED ON ANDROID Name NRP Department Supervisor
: : : :
Andi Riski Alvianto 1210 100 040 Mathematics FMIPA – ITS Dr. Darmaji, S.Si, MT
Abstract Currently smartphone usage is very popular by many people, especially Android-based Smartphone. Starting from the grass root to the top ranks of society. One of the features of the smartphone is also much in demand by the people is SMS. SMS is one of the features that are widely used and utilized by society, but there is one problem often encountered by the community in the use of SMS that is SMS messages security problems. Cryptography is one of the solutions that can be utilized and developed to solve the problem of the security of SMS messages. By performing encryption on SMS messages, the SMS messages security will be more awake and safe. Cryptography has many techniques in performing of the encripting SMS messages and one that has a high level of security and the level of difficulty in solving them is the RSA algorithm. So that person or parties who has no responsibility will have difficulty in performing actions. In this final project, the author develops an application on smartphone based on Android to modify SMS to ciphertext so that information contents from SMS was not known by others. For immediate delivery system SMS encrypt message to ciphertext then sending destination number. For the acceptance SMS system to decrypt ciphertext to plaintext use the key that inputed by receiver and display original message to recipients. This application can be utilized by someone who want to send a secret information to others through SMS without fear information from that message
ix
will be known by another. The methods used to encrypt and describe message is algoritma RSA and implementation using Eclipse IDE. Keywords: Android, Smartphone, encryption, decryption, RSA
x
SMS,
cryptography,
KATA PENGANTAR Puji syukur penulis panjatkan kehadirat Allah SWT, yang telah memberikan rahmat dan hidayah-Nya serta kesehatan dan keteguhan hati sehingga penulis dapat menyelesaikan Tugas Akhir yang berjudul “Pengaman Pengiriman Pesan Via SMS dengan Algoritma RSA Berbasis Android” sebagai syarat kelulusan dalam menempuh program S-1 Jurusan Matematika FMIPA ITS Surabaya. Dalam proses pembuatan Tugas Akhir ini, penulis mendapat bantuan dan dukungan dari berbagai pihak. Untuk itu penulis mengucapkan terima kasih kepada : 1. Ibu Dr. Erna Apriliani, M.Si selaku Ketua Jurusan Matematika FMIPA ITS. 2. Bapak Dr. Darmaji, S.Si, MT selaku Dosen Pembimbing Tugas Akhir yang telah banyak membantu, membimbing dan memberikan motivasi kepada penulis dalam penyusunan laporan Tugas Akhir ini. 3. Bapak Dr. Chairul Imron, M.I.Komp selaku Koordinator Tugas Akhir Jurusan Matematika FMIPA ITS. 4. Ibu Dra. Farida Agustini Widjajati, MS selaku dosen wali penulis yang telah memberikan motivasi. 5. Bapak dan ibu dosen serta seluruh staf Tata Usaha dan Laboratorium Jurusan Matematika FMIPA ITS yang tidak dapat penulis sebutkan satu persatu. Penulis menyadari bahwa laporan tugas akhir ini masih jauh dari kesempurnaan. Untuk itu penulis mengharap saran dan kritik yang membangun. Akhir kata penulis mohon maaf sebesar-besarnya apabila ada kesalahan yang diperbuat, baik sengaja maupun tidak. Semoga tugas akhir bermanfaat bagi pembaca khususnya dan rekan-rekan mahasiswa lainnya. Surabaya, Februari 2015 Penulis
xi
Special thank’s to: 1. Bapak dan Ibu yang telah mendukung dan memberi semangat serta doa dalam pengerjaan Tugas Akhir ini. Juga adikku Arif Krisdiyanto yang selalu memberikan refreshing pikiran. 2. Penguji sidang Tugas Akhir Pak Basuki, Pak Budi, Pak Sutrisno dan Pak Suhud terimakasih atas saran dan masukannya dalam koreksi Tugas Akhir ini. 3. Teman-teman dekatku di jurusan Matematika angkatan 2010 yang selalu bersama di jurusan dan saling menyemangati dalam kuliah, yang selalu dapat diajak “gila-gilaan” bersama, yang dapat diajak membuat “LAN” bersama. Ketika aku sangat bosan, berkumpul bersama kalian adalah salah satu pembangkit mood-ku. thanks to Om Don (Romdoni), El Cho (Khoir), Minho (Romi), Bang Gos (Aji), Kentang (Akhmad), Ridho, Zaky, Tomy dan tetua kita Mas Ipin, Mas Pandi, Bang Satria dan lain-lain yang tidak dapat disebutkan satu-persatu. 4. Juga untuk Master Danang dan Mas Arif yang bersedia membantu dalam pembuatan program. Thank’s bro. 5. Teman-teman seperjuangan TA, terutama yang selalu ada di ruang TA Lab Komputasi. Selamat datang dalam dunia yang penuh perjuangan. Dan untuk yang dalam proses semangat!! 6. Teman-teman arITSmatics yang telah memberikan dukungan serta berbagi suka dan duka selama kuliah di kampus perjuangan ini. 7. Adek-adekku terima kasih atas motivasi dan dukungannya dalam menyemangati penyelesaian Tugas Akhir ini. 8. Sahabat, teman-teman serta seluruh pihak yang tidak dapat penulis sebutkan satu persatu. Semoga Allah membalas dengan kebaikan yang berlimpah. Amin.
xii
DAFTAR ISI HALAMAN JUDUL ........................................................ LEMBAR PENGESAHAN ............................................. ABSTRAK ........................................................................ ABSTRACT ....................................................................... KATA PENGANTAR ..................................................... DAFTAR ISI .................................................................... DAFTAR GAMBAR ....................................................... DAFTAR TABEL ............................................................ DAFTAR NOTASI ..........................................................
i v vii ix xi xiii xvii xix xxi
BAB I PENDAHULUAN 1.1 Latar Belakang ...................................................... 1.2 Rumusan Masalah ................................................. 1.3 Batasan Masalah ................................................... 1.4 Tujuan ................................................................... 1.5 Manfaat ................................................................. 1.6 Sistematika Penulisan ...........................................
1 3 4 4 4 4
BAB II TINJAUAN PUSTAKA 2.1 Masalah Keamanan ............................................... 2.2 Aspek-Aspek Keamanan ...................................... 2.3 Serangan Keamanan ............................................. 2.3.1 Serangan Pasif ............................................ 2.3.2 Serangan Aktif ............................................ 2.4 Pengertian Kriptografi .......................................... 2.4.1 Algoritma Kunci Simetri ............................ 2.4.2 Algoritma Kunci Asimetri .......................... 2.5 Sistem Kriptografi RSA ........................................ 2.5.1 Teorema Fermat ......................................... 2.5.2 Fungsi Euler ............................................... 2.5.3 Algoritma RSA ........................................... 2.5.4 Algoritma Pembangkitan Kunci RSA ........ 2.5.5 Algoritma Enkripsi .....................................
7 8 8 9 10 11 12 13 13 14 14 14 15 16
xiii
2.5.6 Algoritma Dekripsi ..................................... 2.6 Sistem ASCII ........................................................ 2.7 Sistem Operasi Android ....................................... 2.7.1 Pengertian ROOT ....................................... 2.7.2 Custom ROM Android ............................... 2.7.3 Flashing OS ................................................ 2.7.4 Modifikasi Kernel ...................................... 2.7.5 Keuntungan dan Kerugian Custom ROM .. 2.8 Short Message Service (SMS) ..............................
17 18 20 23 23 24 24 25 26
BAB III METODE PENELITIAN 3.1 Identifikasi Masalah ............................................. 3.2 Komparasi Penelitian Terdahulu .......................... 3.3 Studi Literatur ....................................................... 3.4 Pengembangan Perangkat Lunak .......................... 3.4.1 User Requirement ........................................ 3.4.2 Perancangan Perangkat Lunak .................... 3.5 Implementasi Perangkat Lunak ............................ 3.6 Uji Coba Perangkat Lunak ................................... 3.7 Penarikan Simpulan dan Saran .............................
29 29 29 29 29 30 30 31 31
BAB IV ANALISA DAN PERANCANGAN 4.1 Deskripsi Sistem ................................................... 4.2 Analisa Sistem ...................................................... 4.2.1 Analisa Kebutuhan ..................................... 4.2.2 Software Requirement Spesification (SRS) . 4.2.3 Analisa Algoritma RSA sebagai Kunci Publik Cryptosystem ................................... 4.2.4 Analisa Perancangan Perangkat Lunak ...... 4.3 Perancangan Perangkat Lunak .............................. 4.3.1 Perancangan Flowchart Perangkat Lunak .. 4.3.2 Perancangan Data Context Diagram .......... 4.3.3 Perancangan Data Flow Diagram .............. 4.3.3.1 DFD Level 1 ................................... 4.3.3.2 DFD Level 2 Proses Enkripsi .........
xiv
33 36 36 37 38 39 39 39 40 41 41 42
4.3.3.3 DFD Level 2 Proses Dekripsi ......... 4.4 Perancangan Proses dari Perangkat Lunak ........... 4.4.1 Penggunaan Kelas BigInteger .................... 4.4.2 Pembuatan Generator Bilangan Prima ....... 4.4.3 Pembentukan Kunci Publik dan Kunci Privat dengan Algoritma RSA .................... 4.4.4 Proses Enkripsi dengan Algoritma RSA .... 4.4.5 Proses Dekripsi dengan Algoritma RSA .... 4.4.6 Perancangan Proses Pengiriman Pesan ...... 4.4.7 Perancangan Proses Penerimaan Pesan ...... 4.5 Perancangan Tampilan Perangkat Lunak ............. 4.5.1 Tampilan Layout Main ............................... 4.5.2 Tampilan Layout Tulis Pesan ..................... 4.5.3 Tampilan Layout Inbox .............................. 4.5.4 Tampilan Layout Baca Pesan ..................... BAB V PEMBAHASAN DAN PENGUJIAN 5.1 Pembahasan Aplikasi Pengaman SMS dengan Algoritma RSA ..................................................... 5.1.1 Pembahasan Tampilan Layout Main .......... 5.1.2 Pembahasan Tampilan Layout Tulis Pesan 5.1.3 Pembahasan Tampilan Layout Inbox ......... 5.1.4 Pembahasan Tampilan Layout Baca Pesan 5.2 Proses Uji Coba Aplikasi Pengaman SMS ........... 5.3 Uji Coba Validitas Pesan Saat Enkripsi dan Dekripsi ................................................................ 5.4 Uji Coba Response Time pada Enkripsi dan Dekripsi ................................................................
43 44 44 44 45 45 46 46 47 47 48 49 50 51
53 54 58 67 72 75 79 80
BAB VI PENUTUP 6.1 Simpulan ............................................................... 6.2 Saran .....................................................................
83 83
DAFTAR PUSTAKA ......................................................
87
xv
LAMPIRAN A. Cara Menginstal Perangkat Lunak ....................... B. Syarat Pendukung Perangkat Lunak ..................... C. Data-Data Uji Coba .............................................. C.1 Percobaan untuk Response Time Proses Enkripsi ....................................................... C.2 Percobaan untuk Response Time Proses Dekripsi ....................................................... C.3 Validitas Pesan Saat Enkripsi dan Dekripsi BIODATA PENULIS
xvi
87 87 87 87 88 90
DAFTAR TABEL Tabel 2.1 Tabel ASCII .................................................... Tabel 4.1 Spesifikasi kebutuhan perangkat lunak ........... Tabel 5.1 Validitas pesan saat enkripsi dan dekripsi .......
xix
19 37 79
”Halaman ini sengaja dikosongkan”
xx
DAFTAR GAMBAR Gambar 2.1 Gambar 2.2 Gambar 4.1 Gambar 4.2 Gambar 4.3 Gambar 4.4 Gambar 4.5 Gambar 4.6 Gambar 4.7 Gambar 4.8 Gambar 4.9 Gambar 4.10 Gambar 4.11 Gambar 4.12 Gambar 5.1 Gambar 5.2 Gambar 5.3 Gambar 5.4 Gambar 5.5 Gambar 5.6 Gambar 5.7 Gambar 5.8 Gambar 5.9 Gambar 5.10 Gambar 5.11 Gambar 5.12 Gambar 5.13 Gambar 5.14 Gambar 5.16
Serangan terhadap keamanan ..................... Proses enkripsi dan dekripsi ....................... Pengiriman dan Penerimaan SMS .............. Use Case Diagram System ......................... Flowchart Sistem dengan Algoritma RSA . DCD Aplikasi Pengaman SMS .................. DFD level 1 ................................................ DFD level 2 Proses Enkripsi ...................... DFD level 2 Proses Dekripsi ...................... Flowchart Aplikasi Pengaman SMS ........... Rancangan Tampilan untuk Layout Main .. Tampilan Layout Tulis Pesan ..................... Tampilan Layout Inbox .............................. Tampilan Layout Baca Pesan ..................... Tampilan Awal ........................................... Flowchart Pemanggilan Class .................... Tampilan Tulis Pesan ................................. Function pada class tulis() ......................... Tampilan Inbox .......................................... Flowchart Proses Inbox .............................. Tampilan Baca Pesan ................................. Flowchart Proses Tampilan Baca Pesan .... Membuka Aplikasi Pengaman SMS ........... Proses Pengiriman SMS ............................. Tampilan Inbox Bawaan Android .............. Tampilan Inbox pada Pengaman SMS ....... Proses Dekripsi Benar ................................ Proses Dekripsi Salah ................................. Grafik Response Time enkripsi berdasarkan jumlah karakter pesan .......................... Gambar 5.17 Grafik Response Time dekripsi berdasarkan jumlah karakter pesan ..........................
xvii
9 12 34 35 39 40 41 42 43 48 49 50 51 52 54 57 58 59 68 68 72 73 76 76 77 77 78 78 81 81
”Halaman ini sengaja dikosongkan”
xviii
DAFTAR NOTASI M
:
C
:
K
:
Ee
:
Dd
:
p, q n e d m c
: : : : : :
Pesan atau data dalam bentuk aslinya yang dapat terbaca. Untuk selanjutnya digunakan istilah plaintext sebagai padanan dari kata teks asli. Plaintext adalah masukan bagi algoritma enkripsi Pesan dalam bentuk tersembunyi. Untuk selanjutnya digunakan istilah ciphertext sebagai padanan dari kata teks sandi. Ciphertext merupakan plaintext yang telah disamarkan dengan metode kriptografi tertentu. Ciphertext adalah keluaran dari algoritma enkripsi Masukan bagi algoritma enkripsi dan merupakan nilai yang bebas terhadap teks asli serta menentukan hasil keluaran algoritma enkripsi. Untuk selanjutnya digunakan istilah secret key sebagai padanan dari kata kunci rahasia Algoritma enkripsi atau encryption function, dimana e ϵ K merupakan encryption key yang menentukan perubahan tiap-tiap elemen M secara bijeksi (hubungan satu untuk satu) menjadi C sehingga tiap plaintext menjadi tersamar dalam bentuk ciphertext Algoritma dekripsi atau decryption function, dimana d ϵ K merupakan decryption key yang menentukan perubahan tiap-tiap elemen C secara bijeksi menjadi M sehingga tiap ciphertext kembali kebentuk plaintext semula Bilangan prima yang dirahasiakan Hasil kali p dan q Kunci enkripsi Kunci dekripsi Plaintext Ciphertext
xxi
”Halaman ini sengaja dikosongkan”
xxii
DAFTAR PUSTAKA [1] [2]
[3] [4]
[5]
[6]
[7] [8] [9]
Enterprise, J. (2013). “Memahami Pemrograman Android secara cepat dan mudah”. Cetakan Pertama. Elex Media Komputindo. Jakarta. Heriyanto, T., dan Arradian, D. (2014). “Perkembangan Android Bagi Pendidikan”. http://rastafarareggaeman.blogspot.com. (diakses pada tanggal 25 November 2014) Nosrati, M. (2012). “Mobile Computing : Principles, Devices, and Operating Systems”. World Applied Programming Journal. Noor, A. R. (2008). “Tarif SMS di Indonesia, Mahal atau Murah”. http://inet.detik.com/read/2008/01/16/094747/879587/328/t arif-sms-di-indonesia-mahal-atau-murah. (diakses pada tanggal 7 November 2014) Kastawan, I K. (2003). “Pembuatan Perangkat Lunak Pengaman Pengiriman Pesan Via Email dengan Algoritma RSA”. Tugas Akhir Jurusan Matematika Institut Teknologi Sepuluh Nopember. Surabaya. Sunarsa, R. (2012). “Membedakan Encoding dan Encryption”. http://blog.randisunarsa.web.id/?p=271 (diakses pada tanggal 28 November 2014) Ariyus, D. (2008). “Pengantar Ilmu Kriptografi – Teori Analisis dan Implementasi”. Edisi Pertama. Penerbit ANDI. Yogyakarta. Sadikin, R. (2012). “Kriptografi untuk Keamanan Jaringan”. Edisi Pertama. Penerbit ANDI. Yogyakarta. Ariyus, D. (2006). “Kriptografi – Keamanan Data dan Komunikasi”. Cetakan Pertama. GRAHA ILMU. Yogyakarta.
85
86 [10] Elgin, B. (2005). “Google Buys Android for Its Mobile Arsenal”. Bloomberg Businessweek. Bloomberg. Diarsipkan dari aslinya tanggal 24 Februari 2011. [11] Welch, C. (2013). “Before it took over smartphones, Android was originally destined for cameras”. The Verge. Diakses tanggal 1 Mei 2013. [12] Romsy. (2011). “Sistem Operasi pada Handphone”.
http://romsyuchiha.wordpress.com/2011/05/18/sistemoperasi-pada-handphone/. (diakses pada tanggal 2 Desember 2014) [13] Sirohito, A. (2012). “Memaksimalkan Kemampuan Android”. http://sirohito.wordpress.com/2012/07/28/memaksima lkan-kemampuan-android/. (diaksses pada tanggal 30 November 2014)
[14] Nadia. (2013). “Pengertian SMS (Short Message Service)”. Rapendik. http://rapendik.com/program/pengayaanpembelajaran/petik /561-pengertian-sms-short-message-service. (diakses pada tanggal 11 Februari 2014) [15] Faritzah. (2013). “Layanan Pesan Singkat”. http://modernpyramid.wordpress.com/2013/01/18/layananpesan-singkat. (diakses pada tanggal 1 Desember 2014) [16] Safaat, N. (2013). “Berbagai Implementasi dan Pengembangan Aplikasi Mobile Berbasis Android”. Cetakan Pertama. INFORMATIKA. Bandung. [17] Alfatta, H. (2007). “Analisis dan Perancangan Sistem Informasi”. Edisi Pertama. Penerbit ANDI. Yogyakarta.
BIODATA PENULIS Penulis memiliki nama lengkap Andi Riski Alvianto atau biasa dipanggil Andi. Penulis dilahirkan di Nganjuk pada 28 April 1991 dan merupakan anak pertama dari 2 bersaudara. Pendidikan formal yang pernah ditempuh yaitu di TK Nurul Huda Tambun Selatan, SDN Mekarsari 1 Tambun SelatanBekasi, MTsN Nganjuk, dan SMKN 1 Nganjuk. Setelah lulus dari SMK, penulis mendaftar program beasiswa Bidikmisi dan diterima di Jurusan Matematika FMIPA ITS pada tahun 2010 dan terdaftar dengan NRP. 1210 100 040. Di Jurusan Matematika FMIPA ITS, penulis mengambil bidang minat Ilmu Komputer. Penulis aktif di beberapa organisasi intra kampus diantaranya kepengurusan HIMATIKA sebagai staf Departemen Dalam Negeri periode 2011-2012 dan periode 20122013. Selain itu, penulis juga aktif dalam kepengurusan BEM FMIPA ITS sebagai staf Departemen Sosial Masyarakat periode 2011-2012 dan Kepala Biro Lingkungan Departemen Sosial Masyarakat periode 2012-2013. Penulis juga mengikuti Lembaga Dakwah Jurusan sebagai staf kaderisasi Ibnu Muqlah periode 2012-2013. Selain intra kampus, penulis juga mengikuti organisasi ekstra kampus sebagai staf UKM Olah Raga Air ITS Divisi Renang. Penulis juga aktif dalam berbagai kegiatan pelatihan kemahasiswaan, diantaranya LKMM Pra TD FMIPA 2010, LKMM TD HIMATIKA 2011. Disamping itu pada semester 7 penulis menjadi asisten dosen matakuliah Microsoft SQL Server 2005 di PAPSI. Untuk kritik, saran, informasi dan pertanyaan yang berhubungan mengenai Tugas Akhir ini dapat dikirimkan melalui e-mail ke
[email protected].
BAB I PENDAHULUAN 1.1 Latar Belakang Smartphone berkembang pesat saat ini, dunia terasa semakin sempit. Sekarang ini telepon selular (ponsel) seperti menjadi kebutuhan pribadi yang harus terpenuhi untuk bisa saling berkomunikasi antar orang. Jika membicarakan tentang smartphone, maka Android lebih dipilih dibandingkan dengan platform lainnya dikarenakan pasarnya sangat besar. Berbeda dengan iOS yang cenderung eksklusif, Android bisa diaplikasikan pada ponsel apapun. Inilah yang membuat pasar aplikasi berbasis Android lebih luas [1]. Penggunaan smartphone atau mobile phone pintar di Indonesia melonjak 28% sejak tahun 2011. Lebih lanjut secara rinci pengguna android sendiri meningkat 15 kali lipat, tahun 2011 pengguna android pada salah satu jaringan telepon yaitu jaringan Telkomsel 170.000 orang, sementara sampai saat ini sudah menembus 2,5 juta orang. Kelebihan-kelebihan yang dimiliki mobile phone android menyebabkan pengembangan aplikasi smartphone ini berkembang pesat [2]. Sistem operasi Android dikenalkan pada tahun 2008 dan pada tahun 2012 Android telah menguasai 59% pasar smartphone dunia. Sehingga membuat android menjadi sistem operasi mobile phone yang terpopuler di dunia saat ini [3]. Mobile phone android dapat digunakan untuk berbagai aktivitas karena memuat banyak fitur dan aplikasi. Salah satu fitur atau aplikasi yang digunakan agar dapat saling berkomunikasi dan untuk mengirimkan pesan adalah dengan menggunakan SMS (Short Message Service). SMS merupakan salah satu sarana komunikasi antara semua orang di dunia. SMS sangat populer di Eropa, Asia dan Australia. Dimulai dari sekedar mengirim pesan dari jaringan lokal hingga mengirim pesan antar negara. Teknologi ini banyak dipilih karena selain praktis, biaya yang harus dikeluarkan untuk mengirimkan 1
2 satu SMS cukup terjangkau (di Indonesia, tergantung operator sebuah SMS berkisar antara Rp. 250,- sampai Rp. 350,- saja). Karena faktor inilah, SMS telah banyak digunakan. Namun pesan yang dikirimkan pada orang yang diinginkan belum tentu terjaga kerahasiaannya [4]. Kasus penyadapan telah ada sekitar 100 tahun yang lalu. Salah satu contoh kasus penyadapan yang terkenal yaitu perkara yang dilaporkan pada tahun 1867 oleh sebuah makelar saham Wall Street bekerjasama dengan Western Union untuk melakukan penyadapan ke operator telegrap yang dikirim ke koran yang ada di Timur Tengah kemudian pesan telegrap tersebut diganti dengan yang palsu. Berbagai alat komunikasi yang ada saat ini belum tentu aman untuk digunakan, karena belum ada standar keamanan yang dapat digunakan oleh alat-alat tersebut. Oleh karena itu, komunikasi ini sangat rentan terhadap serangan pihak ketiga yang seringkali sangat merugikan. Untuk menjaga agar pesan yang dikirimkan tidak diketahui orang lain maka diperlukan suatu perangkat lunak yang berfungsi untuk mengamankan pengiriman pesan tersebut. Untuk itulah akan dibuat suatu perangkat lunak berbasis Android yang berfungsi untuk enkripsi (encryption) dan dekripsi (decryption) pesan yang telah dibuat tersebut. Proses enkripsi sendiri adalah sebuah proses yang melakukan perubahan sebuah kode dari yang bisa dimengerti menjadi sebuah kode yang tidak bisa dimengerti (tidak terbaca). Untuk melakukan pengamanan pesan khususnya via SMS dengan menggunakan teknik kriptografi dengan menggunakan algoritma RSA. Dari sekian banyak algoritma kriptografi kunci-publik yang pernah dibuat, algoritma yang paling populer adalah algoritma RSA. Algoritma RSA dibuat oleh 3 orang peneliti dari MIT (Massachussets Institute of Technology) pada tahun 1976, yaitu Ron Rivest, Adi Shamir, dan Leonard Adleman. Keamanan algoritma RSA terletak pada sulitnya memfaktorkan bilangan prima yang relatif besar. Pemfaktoran dilakukan untuk memperoleh kunci privat. Selama pemfaktoran bilangan prima
3 yang besar belum ditemukan algoritma yang berhasil memecahkan, maka selama itu pula keamanan algoritma RSA tetap terjamin. Pada penelitian sebelumnya Algoritma RSA telah digunakan dalam beberapa penyelesaian masalah. Seperti salah satu penyelesaian masalah terkait tentang pengamanan pesan untuk mengamankan pesan email dengan algoritma RSA. Pengamanan yang dilakukan bertujuan untuk mengamankan pesan yang dikirimkan melalui email agar terjaga kerahasiaannya saat sampai ke penerima pesan [5]. Dalam tugas akhir ini, seorang pengirim pesan (sender) menuliskan pesan yang akan dikirimkan pada penerima pesan (receiver), setelah pesan ditulis pengirim akan melakukan proses enkripsi pesan yang akan dikirim agar pesan tersandikan dan tidak dapat terbaca. Aplikasi ini akan menampilkan kunci publik, kunci privat, dan nilai modulus serta pesan yang telah terenkripsi. Kemudian pengirim melakukan proses pengiriman pesan yang telah terenkripsi beserta kunci privat dan nilai modulusnya, setelah terkirim maka pengirim akan menerima laporan pengirimannya. Dari pihak penerima akan menerima pesan yang terenkripsi beserta kuncinya dalam kotak masuk. Penerima akan melakukan proses dekripsi pesan yang tersandikan setelah memilihnya dan menuliskan kuncinya. Setelah proses dekripsi dijalankan maka akan ditampilkan pesan asli yang dikirimkan oleh pengirim pesan agar dapat dibaca. 1.2 Rumusan Masalah Berdasar latar belakang yang ada, masalah yang muncul dalam tugas akhir ini adalah: a. Bagaimana mengimplementasikan algoritma RSA pada telepon seluler berbasis Android untuk mengamankan pengiriman SMS. b. Bagaimana mengembangkan perangkat lunak pada telepon seluler berbasis Android yang bisa mengenkripsi dan
4 mendekripsi pesan tersebut menggunakan suatu algoritma kriptografi yaitu algoritma RSA. 1.3 Batasan Masalah Dalam penulisan tugas akhir ini akan dibatasi pada masalah sebagai berikut : a. Fungsi editornya terbatas hanya pada mengirim, menerima, enkripsi dan deskripsi pesan melalui emulator Android. b. Plainteks yang akan diproses berdasarkan ASCII. c. Pesan yang dikirim bersifat personal atau antar dua pengguna saja. 1.4 Tujuan Tujuan penulisan tugas akhir ini adalah untuk menerapkan metode pengamanan data, khususnya algoritma RSA, untuk aplikasi pada perangkat lunak yang bisa mengamankan pesan dalam bentuk SMS yaitu suatu perangkat lunak yang berbentuk editor khusus yang mirip dengan aplikasi yang ada di pasaran. 1.5 Manfaat Manfaat yang didapat dari penulisan tugas akhir ini berdasarkan latar belakang dan permasalahan tersebut adalah untuk menjaga kerahasiaan pengiriman pesan yang dilakukan, sehingga dapat menjaga privasi dari pihak-pihak yang tidak bertanggungjawab. 1.6 Sistematika Penulisan Tugas akhir ini ditulis dengan sistematika penulisan sebagai berikut: BAB I PENDAHULUAN Berisi tentang latar belakang, rumusan dan batasan masalah serta tujuan dan manfaat penelitian. BAB II TINJAUAN PUSTAKA Memaparkan dasar teori yang digunakan penulis dalam mengerjakan tugas akhir.
5 BAB III METODOLOGI PENELITIAN Menjelaskan alur kerja dan metode yang digunakan penulis dalam mengerjakan tugas akhir. BAB IV ANALISA DAN PERANCANGAN Menyajikan analisa dan perancangan data yang digunakan untuk menyelesaikan permasalahan dalam mencapai tujuan penelitian. BAB V PEMBAHASAN DAN PENGUJIAN Bab ini menjelaskan mengenai pembahasan dan hasil pengujian implementasi pada setiap proses dalam mengidentifikasi ciphertext dan melakukan pembahasan terhadap hasil yang diperoleh. BAB VI PENUTUP Bab ini merupakan penutup, berisi tentang kesimpulan yang dapat diambil dan saran yang selayaknya dilakukan bila tugas akhir ini dilanjutkan.
6
“ Halaman ini sengaja dikosongkan “
BAB II TINJAUAN PUSTAKA Dalam pengerjaan tugas akhir ini diperlukan tinjauan pustaka yang menjadi dasar teori pendukung untuk menyelesaikan masalah yang diteliti. 2.1 Masalah Keamanan Kehidupan kita saat ini telah dilingkupi oleh kriptografi. Mulai dari mengakses internet, mengaktifkan peluru kendali, hingga transaksi di bank seperti transaksi di mesin ATM dan transaksi dengan kartu kredit pun sudah menggunakan kriptografi. Begitu pentingnya kriptografi untuk keamanan informasi (information security), sehingga jika berbicara masalah keamanan yang berkaitan dengan penggunaan komputer, maka orang tidak bisa memisahkannya dengan kriptografi. Masalah keamanan merupakan salah satu aspek penting dari sebuah sistem informasi. Salah satu hal penting dalam komunikasi menggunakan komputer dan dalam jaringan komputer untuk menjamin keamanan pesan, data atau pun informasi adalah enkripsi. Enkripsi dapat diartikan sebagai sebuah proses yang dilakukan untuk mengubah pesan asli menjadi pesan yang tersandikan. Sebuah cipher adalah sebuah algoritma untuk menampilkan enkripsi dan kebalikannya dekripsi. Informasi yang asli disebut sebagai plaintext, dan bentuk yang sudah dienkripsi disebut sebagai ciphertext. Pesan ciphertext berisi seluruh informasi dari pesan plaintext, tetapi tidak dalam format yang dapat dibaca oleh manusia ataupun komputer tanpa menggunakan mekanisme yang tepat untuk melakukan dekripsi. Prosedur enkripsi sangat bervariasi tergantung pada kunci yang akan mengubah rincian dari operasi algoritma. Tanpa menggunakan kunci, cipher tidak dapat digunakan untuk proses dekripsi. Sistem cipher merupakan suatu sistem yang telah siap untuk di otomasi, jadi teknik ini digunakan dalam sistem keamanan jaringan komputer. Keamanan sistem dibutuhkan 7
8 karena nilai informasi menjadi sangat penting dan menuntut untuk mengakses dan menyediakan informasi secara cepat dan akurat menjadi sangat esensial bagi sebuah organisasi [6]. 2.2 Aspek-Aspek Keamanan Agar lebih bisa memahami jenis-jenis ancaman terhadap keamanan, kita perlu mendefinisikan aspek-aspek keamanan terlebih dahulu. Keamanan data dan informasi memiliki beberapa aspek penting, antara lain : a. Authentification : agar penerima informasi dapat memastikan keaslian pesan, bahwa pesan itu datang dari orang yang dimintai informasi. Dengan kata lain, informasi itu benar-benar datang dari orang yang dikehendaki. b. Integrity : keaslian pesan yang dikirim melalui jaringan dan dapat dipastikan bahwa informasi yang dikirim tidak dimodifikasi oleh orang yang tidak berhak. c. Non-repudiation : pengirim tidak dapat mengelak bahwa dialah yang telah mengirim informasi tersebut. d. Authority : Informasi yang berada pada sistem jaringan tidak dapat dimodifikasi oleh pihak yang tidak berhak mengaksesnya. e. Confidentiality : usaha untuk menjaga informasi dari orang yang tidak berhak mengakses. Kerahasiaan ini biasanya berhubungan dengan informasi yang diberikan ke pihak lain. f. Availability : aspek ini berhubungan dengan ketersediaan informasi ketika dibutuhkan. [7] 2.3 Serangan Keamanan Sistem keamanan jaringan yang dioperasikan pada jaringan publik rentan terhadap serangan oleh siapapun. Orang yang berusaha meruntuhkan keamanan jaringan disebut sebagai penyerang. Misalnya penyerang ingin mengungkap isi teks asli sehingga dia dapat mengungkap teks sandi lainnya kemudian informasi atau data yang ada dalam sistem komputer dirusak, dihapus, sehingga jika dibutuhkan maka sudah tidak ada lagi. Itu
9 termasuk serangan serius jika data tidak dapat lagi dilihat. Secara umum serangan pada sistem keamanan dapat dikategorikan menjadi 2 jenis yaitu serangan pasif (passive attack) dan serangan aktif (active attack) seperti Gambar 2.1 dibawah ini :
Gambar 2.1 Serangan terhadap keamanan [8] 2.3.1 Serangan Pasif Pada serangan pasif, penyerang hanya mengumpulkan data yang melintas pada jaringan publik (jaringan yang bisa diakses oleh penyerang). Serangan pasif tidak melakukan modifikasi data yang melintas atau merusan sistem, penyerang hanya punya kemampuan membaca saja (read only). Lalu berdasarkan data yang dikumpulkan, penyerang melakukan analisis untuk menggagalkan keamanan jaringan. Karena tidak melakukan perubahan data dan mengganggu sistem, serangan pasif susah untuk dideteksi namun serangan pasif dapat dicegah dengan cara misalkan selalu menggunakan sandi (encryption) ketika pengiriman pesan. Oleh karena itu, penekanan untuk mengatasi serangan pasif lebih pada pencegahan dari pada pendeteksian. Berikut ini beberapa jenis serangan yang digolongkan sebagai serangan pasif, antara lain:
10 a.
b.
Snooping Snooping merujuk pada kegiatan yang bermaksud mendapatkan data yang tengah terkirim pada jaringan biasanya melalui akses yang tidak berwenang. Contoh aktivitas snooping misalnya sebuah email disadap oleh penyerang. Untuk mengalahkan penyerang sehingga aktivitas snooping tidak bermakna, data yang terkirim dibuat tidak kasat mata (nonintelligible) dengan menggunakan mekanisme penyandian (encipherment). Traffic Analysis Traffic analysis merupakan kegiatan serangan pasif dengan melakukan monitoring terhadap lalu lintas data pada jaringan. Data-data lalu lintas jaringan dikumpulkan dan kemudian dianalisis sehingga penyerang dapat mengetahui maksud data-data itu.
2.3.2 Serangan Aktif Sebuah serangan aktif dapat mengakibatkan perubahan data yang terkirim dan jalannya sistem akan terganggu. Pada serangan aktif seakan-akan penyerang memperoleh kemampuan untuk mengubah data pada lalu lintas data selain kemampuan baca. Jenis-jenis serangan aktif adalah sebagai berikut: a. Masquerade Masquerade adalah serangan aktif yang dilakukan oleh penyerang dengan cara penyerang mengambil alih (menirukan) perilaku pengirim atau penerima. Misalnya pada saat Alice ingin membuat kunci bersama dengan Bob, Charlie mengambil alih peran Bob sehingga Alice tidak sadar bahwa dia mengirim pesan ke Charlie bukan ke Bob. b. Modification Modification adalah serangan aktif yang dilakukan oleh penyerang dengan cara penyerang mengambil alih jalur komunikasi untuk mengubah atau menghapus atau menunda pesan yang sedang terkirim untuk keuntungan penyerang. Contohnya sebuah pesan “Kirim 10000 ke akun Alice”
11
c.
d.
kemudian pesan tersebut diubah oleh Charlie menjadi “Kirim 10000 ke akun Charlie”. Replay Replay adalah serangan aktif yang terdiri atas pencatatan secara pasif data unit dan transmisi ulang untuk menimbulkan efek yang diinginkan penyerang. Contohnya Charlie pernah meminta Bob mengirim 10000 ke Charlie, lalu Bob mengirim pesan “Kirim 10000 ke akun Charlie” ke Bank, Charlie mencatat pesan “Kirim 10000 ke akun Charlie” dan mengirim ulang ke Bank. Denial of Service Denial of service adalah serangan aktif yang bertujuan agar sistem menjadi collapse sehingga tidak mampu memberikan respons atau layanan yang semestinya kepada pengguna. Serangan ini biasanya dilakukan dengan membuat sesrver menjadi overload dengan permintaan bodong (dummy).
2.4 Pengertian Kriptografi Kriptografi berasal dari bahasa yunani, menurut bahasa dibagi menjadi dua kata yaitu kripto yang berarti rahasia dan graphia yang berarti tulisan. Menurut terminologinya kriptografi adalah ilmu dan seni untuk menjaga keamanan pesan ketika pesan dikirim dari satu tempat ketempat lain [9]. Kriptografi bisa dianggap sebagai seni penyandian untuk merahasiakan informasi dan sebaliknya, seni untuk memecahkan kriptografi dikenal sebagai sebutan kriptanalisis dan gabungan dari keduanya disebut kriptologi. Sebuah skema enkripsi dan deskripsi pesan terdiri dari sebuah encryption function {Ee: e ϵ K} dan sebuah decryption function { Dd : d ϵ K } dimana e dan d adalah key yang unik yang memenuhi hubungan Dd = Ee-1 sehingga Dd ( Ee ( M ) ) = M. Hubungan proses enkripsi dan dekripsi terhadap pesan dan ciphertext dapat dijelaskan dalam Gambar 2.2 berikut :
12
Gambar 2.2 Proses enkripsi dan dekripsi Dalam notasi persamaan matematika, proses tersebut dapat dituliskan sebagai berikut: Ee (M) = C Dd(C) = M Dd(Ee(M)) = M Dalam kriptografi, cipher yang menggunakan kunci ada dua, yaitu algoritma kunci simetri dan algoritma kunci asimetri. 2.4.1 Algoritma Kunci Simetri Algoritma kunci simetri adalah algoritma enkripsi yang menggunakan kunci yang sama dalam proses enkripsi dan dekripsi. Kunci yang digunakan harus diketahui dan disepakati oleh pengirim dan penerima dan disalurkan melalui channel yang aman. Kekuatan algoritma, persetujuan dan kerahasiaan atas kunci yang digunakan oleh pengirim dan penerima dalam proses enkripsi dan dekripsi menjadi hal yang paling utama dalam algoritma ini. Selain disebut dengan kunci simetri, algoritma ini juga biasa dikenal dengan sebutan single key, one key, secret key ataupun conventional encryption karena kunci enkripsi (e) yang digunakan sama dengan kunci dekripsi (d). Setiap komunikasi antara pengirim dan penerima yang berbeda digunakan kunci
13 yang berbeda pula. Karena itulah jumlah kunci akan terus bertambah seiring bertambahnya jumlah pengirim dan penerima. 2.4.2 Algoritma Kunci Asimetri Algoritma kunci asimetri adalah algoritma yang menggunakan kunci yang berbeda pada proses enkripsi dan dekripsi, dengan kata lain kunci enkripsi tidak sama dengan kunci dekripsi. Walaupun keduanya berbeda tetapi tetap memiliki hubungan dalam pembentukannya, yaitu kunci dekripsi dihitung berdasarkan kunci enkripsi. Dengan adanya hubungan ini sebuah pesan terenkripsi yang dikirim oleh pengirim akan bisa didekripsi dengan tepat oleh penerima dengan menggunakan kunci dekripsi yang dimilikinya walaupun kedua kunci tersebut berbeda. 2.5 Sistem Kriptografi RSA Pada tahun 1977, Ronald L. Rivest, Adi Shamir, dan Leonard M. Adleman merumuskan algoritma praktis yang mengimplementasikan sistem kriptografi kunci publik yang disebut dengan sistem kriptografi RSA. Dalam RSA digunakan beberapa algoritma untuk melakukan enkripsi dan dekripsi. Perbedaan antara enkripsi dan dekripsi hanya terletak pada eksponen yang digunakan. Eksponen disini merupakan bentuk perkalian dengan bilangan yang sama yang dilakukan berulang kali. Sepasang kunci yang dipakai pada kedua proses ini adalah kunci publik (e,n) sebagai kunci enkripsi dan kunci privat d sebagai sebagai kunci dekripsi dimana e, d dan n adalah bilangan bulat positif. Algoritma RSA adalah sebuah block cipher algorithm (algoritma yang bekerja per blok data) yang mengelompokkan plaintext menjadi blok-blok terlebih dahulu sebelum dilakukan enkripsi hingga menjadi ciphertext. Setiap blok plaintext dan ciphertext direpresentasikan sebagai bilangan bulat positif pada interval [0,n-1] untuk sebuah n tertentu. Sebenarnya algoritma RSA memanfaatkan Fungsi Euler dan bentuk umum dari Teorema Fermat.
14 2.5.1 Teorema Fermat Secara umum teorema ini berbunyi: Jika p adalah bilangan prima dan m adalah bilangan bulat yang tidak habis dibagi dengan p, yaitu PBB(m, p) = 1, maka mp-1 ≡ 1 (mod p) (1) 2.5.2 Fungsi Euler Fungsi Euler mendefinisikan (n) untuk n ≥ 1 menyatakan jumlah bilangan bulat positif yang lebih kecil dari n dan relatif prima terhadap n. Dengan memperhatikan Teorema Fermat dan definisi dari Fungsi Euler, dapat diturunkan sebuah bentuk umum dari Teorema Fermat yaitu jika PBB(m, n) = 1, maka mΦ(n) ≡ 1 (mod n) (2) 2.5.3 Algoritma RSA Seperti telah disinggung sebelumnya, algoritma ini diturunkan dari Fungsi Euler dan Teorema Fermat serta memanfaatkan sifat-sifat dari aritmatika modulo. Berikut adalah proses penurunan algoritma dimulai dari persamaan (2). Berdasarkan sifat ak ≡ bk (mod n) maka persamaan (2) dapat ditulis menjadi mkΦ(n) ≡ 1k (mod n) (3) atau mkΦ(n) ≡ 1 (mod n) (4) Berdasarkan sifat ac ≡ bc (mod n) jika a ≡ b (mod n), maka perkalian persamaan (4) dengan m akan menghasilkan mkΦ(n) + 1 ≡ m (mod n) (5) Misalkan e . d = kΦ(n) + 1 (6) Dengan mensubtitusikan persamaan (6) ke dalam persamaan (5) diperoleh me . d ≡ m (mod n) (7) yang artinya perpangkatan m dengan e diikuti dengan perpangkatan dengan d dan dilakukan operasi modulo terhadap n
15 akan menghasilkan m semula. Sehingga enkripsi dan dekripsi dapat dirumuskan sebagai berikut Ee(m) = c ≡ me (mod n) (8) Dd(c) = m ≡ cd (mod n) (9) Karena e . d = d . e, maka Dd(Ee(m)) = Ee(Dd(m)) ≡ me . d (mod n) (10) 2.5.4 Algoritma Pembangkitan Kunci RSA Sebagai algoritma kunci asimetri, algoritma RSA membutuhkan dua kunci yang berbeda untuk enkripsi dan dekripsi. Bilangan yang dipilih sebagai kunci adalah bilangan prima yang besar, dengan alasan pemfaktoran sebuah bilangan hasil perkalian dari dua bilangan prima yang besar menjadi dua bilangan prima yang sesuai akan sangat sulit. Sehingga keamanan dari algoritma RSA dapat terjamin. Kenyataannya, memfaktorkan bilangan bulat menjadi faktor primanya bukanlah pekerjaan yang mudah. Karena belum ditemukan algoritma yang efisien untuk melakukan pemfaktoran. Cara yang biasa digunakan dalam pemfaktoran adalah dengan menggunakan pohon faktor. Jika semakin besar bilangan yang akan difaktorkan, maka semakin lama waktu yang dibutuhkan. Jadi semakin besar bilangan yang difaktorkan, semakin sulit pemfaktorannya, semakin kuat pula algoritma RSA. Berikut cara algoritma pembangkitan pasangan kunci adalah sebagai berikut : 1. Pilih dua bilangan prima sembarang, p dan q secara acak. p ≠ q. Bilangan ini harus cukup besar (minimal 100 digit). 2. Hitung n = p . q (sebaiknya p ≠ q, sebab jika p = q maka n = p2 sehingga, p dapat diperoleh dengan menarik akar pangkat dua dari n). 3. Hitung Φ(n) = (p - 1)(q - 1) menurut fungsi euler. 4. Pilih kunci publik, e yang relatif prima dengan Φ(n). 5. Bangkitkan kunci privat dengan menggunakan persamaan e . d = 1 (mod Φ(n)) ekivalen dengan e . d = k Φ(n)+1,
16 sehingga secara sederhana d dapat dihitung dengan 1 + kΦ(n) d= e Hasil dari algoritma di atas : a. Kunci publik adalah pasangan (e,n) b. Kunci privat adalah pasangan (d,n) Catatan : n tidak bersifat rahasia, sebab diperlukan pada perhitungan enkripsi / dekripsi. Contoh : Misalkan Alice akan membangkitkan kunci publik dan kunci privat miliknya. Alice memiliki p = 47 dan q = 71 (dalam prakteknya, kedua bilangan ini haruslah bilangan besar). Selanjutnya Alice menghitung n = p . q = 47 . 71 = 3337 Φ(n) = (p – 1 ) (q - 1) = 3220 Alice memilih kunci publik e = 79, karena 79 relatif prima dengan 3220. Alice mengumumkan nilai e dan n kepada publik, selanjutnya Alice menghitung kunci dekripsi d seperti dituliskan pada langkah intruksi 5 dengan menggunakan persamaan 1 + k Φ(n) 1 + (k x 3220) d= Atau d = e 79 Dengan mencoba nilai – nilai k = 1, 2, 3, diperoleh nilai d yang bulat adalah 1019. Ini adalah kunci privat untuk mendekripsikan pesan. Kunci privat ini harus dirahasiakan oleh Alice. Jadi perhitungan kunci ini menghasilkan pasangan kunci private dan public : a. Kunci publik : (e = 79, n = 3337) b. Kunci privat: (d=1019, n = 3337) 2.5.5 Algoritma Enkripsi Langkah-langkah pada proses enkripsi adalah sebagai berikut.
17 a. Plaintext diubah menjadi ke dalam bentuk bilangan. Untuk mengubah plaintext yang berupa huruf menjadi bilangan dapat digunakan kode ASCII dalam sistem bilangan desimal. b. Plaintext m dinyatakan menjadi blok-blok m1, m2 ,m3,…. , sedemikian sehingga setiap blok merepresentasikan nilai di dalam selang [0,n-1], sehingga transformasinya menjadi satu ke satu. c. Setiap blok mi dienkripsi menjadi blok ci dengan rumus Ee(m) = mi e mod n = ci 2.5.6 Algoritma Dekripsi Pada algoritma dekripsi, operasi yang dilakukan hampir sama dengan enkripsi akan tetapi eksponen yang digunakan adalah private exponent d untuk mengembalikan pesan seperti semula. Berikut langkah-langkah pada proses dekripsi. a. Setiap blok ciphertext ci didekripsi kembali menjadi blok mi dengan rumus Dd(c) = cd mod n = m b. Kemudian blok-blok m1, m2 ,m3,…. , diubah kembali ke bentuk huruf dengan melihat kode ASCII hasil dekripsi. Contoh : Misalkan Bob mengirim pesan kepada Alice. Pesan (plaintext) yang akan dikirim ke Alice adalah m = HARI INI atau dalam sistem pengkodean ASCII adalah 7265827332737873. Bob memecah m menjadi blok yang lebih kecil, misalnya m dipecah menjadi enam blok yang berukuran 3 digit : m1 = 726 m4 = 273 m2 = 582 m5 = 787 m3 = 733 m6 = 003 Nilai – nilai mi ini masih terletak dalam selang [0, 3337 - 1] agar transformasi menjadi satu ke satu. Bob mengetahui kunci publik Alice adalah e = 79 dan n = 3337. Alice dapat mengenkripsikan setiap blok plaintext sebagai berikut : c1 = 72679 mod 3337 = 215;
18 c2 = 58979 mod 3337 = 776; c3 = 73379 mod 3337 = 1743; c4 = 27379 mod 3337 = 933; c5 = 78779 mod 3337 = 1731; c6 = 00379 mod 3337 = 158; Jadi chipertext yang dihasilkan adalah c = 215 776 1743 933 1731 158. Dekripsi dilakukan dengan menggunakan kunci privat d = 1019. Blok–blok chipertext didekripsikan sebagai berikut : 1. m1 = 2151019 mod 3337 = 726 2. m2 = 7761019 mod 3337 = 589 3. m3 = 17431019 mod 3337 = 733 4. m4 = 9331019 mod 3337 = 273 5. m5 = 17311019 mod 3337 = 787 6. m6 = 1581019 mod 3337 = 003 Blok chipertext diubah menjadi seperti semula menjadi plaintext dan mendapat hasil m = 7265827332737873 atau diubah dalam sistem pengkodean ASCII menjadi HARI INI. 2.6 Sistem ASCII Plaintext yang akan dienkripsi dengan algoritma RSA merupakan angka-angka, sedangkan pesan yang dikirimkan biasanya berbentuk teks atau tulisan. Sehingga dibutuhkan suatu kode yang sifatnya universal untuk mengubah pesan teks menjadi plaintext dalam bentuk bilangan. ASCII (American Standard Code for Information Interchange) atau Kode Standar Amerika untuk pertukaran informasi merupakan suatu standar internasional dalam kode huruf dan simbol seperti Hex dan Unicode tetapi ASCII lebih bersifat universal. Kode ASCII sebenarnya memiliki komposisi bilangan biner sebanyak 8 bit. Dimulai dari 00000000 hingga 11111111. Total kombinasi yang dihasilkan sebanyak 256, dimulai dari kode 0 hingga 255 dalam sistem bilangan Desimal
19 Kode ASCII dari karakter yang umum digunakan dalam penulisan data adalah 32 sampai 126, seperti diberikan pada tabel 2.1 berikut. Tabel 2.1 Tabel ASCII Kode Kode Kode Karakter Karakter Karakter ASCII ASCII ASCII Spasi 32 @ 64 ` 96 ! 33 A 65 a 97 “ 34 B 66 b 98 # 35 C 67 c 99 $ 36 D 68 d 100 % 37 E 69 e 101 & 38 F 70 f 102 ‘ 39 G 71 g 103 ( 40 H 72 h 104 ) 41 I 73 i 105 * 42 J 74 j 106 + 43 K 75 k 107 , 44 L 76 l 108 45 M 77 m 109 . 46 N 78 n 110 / 47 O 79 o 111 0 48 P 80 p 112 1 49 Q 81 q 113 2 50 R 82 r 114 3 51 S 83 s 115 4 52 T 84 t 116 5 53 U 85 u 117 6 54 V 86 v 118 7 55 W 87 w 119 8 56 X 88 x 120 9 57 Y 89 y 121 : 58 Z 90 z 122 ; 59 [ 91 { 123
20 < = > ?
60 61 62 63
\ ] ^ _
92 93 94 95
| } ~
124 125 126
2.7 Sistem Operasi Android Android adalah sistem operasi berbasis Linux yang dirancang untuk perangkat seluler layar sentuh seperti telepon pintar dan komputer tablet. Android awalnya dikembangkan oleh Android, Inc., dengan dukungan finansial dari Google, yang kemudian membelinya pada tahun 2005 [10]. Sistem operasi ini dirilis secara resmi pada tahun 2007, bersamaan dengan didirikannya Open Handset Alliance, konsorsium dari perusahaan-perusahaan perangkat keras, perangkat lunak, dan telekomunikasi yang bertujuan untuk memajukan standar terbuka perangkat seluler. Ponsel Android pertama mulai dijual pada bulan Oktober 2008. Android, Inc. didirikan di Palo Alto, California, pada bulan Oktober 2003 oleh Andy Rubin (pendiri Danger), Rich Miner (pendiri Wildfire Communications, Inc.), Nick Sears (mantan VP T-Mobile), dan Chris White (kepala desain dan pengembangan antarmuka WebTV) untuk mengembangkan "perangkat seluler pintar yang lebih sadar akan lokasi dan preferensi penggunanya" [10]. Tujuan awal pengembangan Android adalah untuk mengembangkan sebuah sistem operasi canggih yang diperuntukkan bagi kamera digital, namun kemudian disadari bahwa pasar untuk perangkat tersebut tidak cukup besar, dan pengembangan Android lalu dialihkan bagi pasar telepon pintar untuk menyaingi Symbian dan Windows Mobile (iPhone Apple belum dirilis pada saat itu) [11]. Meskipun para pengembang Android adalah pakar-pakar teknologi yang berpengalaman, Android Inc. dioperasikan secara diam-diam, hanya diungkapkan bahwa para pengembang sedang menciptakan sebuah perangkat lunak yang diperuntukkan bagi telepon seluler.
21 Google mengakuisisi Android Inc. pada tanggal 17 Agustus 2005, menjadikannya sebagai anak perusahaan yang sepenuhnya dimiliki oleh Google. Pendiri Android Inc. seperti Rubin, Miner dan White tetap bekerja di perusahaan setelah diakuisisi oleh Google. Setelah itu, tidak banyak yang diketahui tentang perkembangan Android Inc., namun banyak anggapan yang menyatakan bahwa Google berencana untuk memasuki pasar telepon seluler dengan tindakannya ini. Di Google, tim yang dipimpin oleh Rubin mulai mengembangkan platform perangkat seluler dengan menggunakan kernel Linux. Google memasarkan platform tersebut kepada produsen perangkat seluler dan operator nirkabel, dengan janji bahwa mereka menyediakan sistem yang fleksibel dan bisa diperbarui. Google telah memilih beberapa mitra perusahaan perangkat lunak dan perangkat keras, serta mengisyaratkan kepada operator seluler bahwa kerjasama ini terbuka bagi siapapun yang ingin berpartisipasi. Dengan menyediakan sebuah platform pengembangan yang terbuka, pengembang Android menawarkan kemampuan untuk membangun aplikasi yang sangat kaya dan inovatif. Pengembang bebas untuk mengambil keuntungan dari perangkat keras, akses informasi lokasi, menjalankan background services, mengatur alarm, tambahkan pemberitahuan ke status bar, dan banyak lagi. Pemakaian sistem operasi Android pada smartphone pada saat ini banyak digunakan oleh perusahaan penghasil telepon seluler. Karena keunggulannya sebagai software yang memakai basis kode komputer yang bisa diunduh oleh pengguna smartphone tanpa membayar biaya aplikasi tersebut. Diyakini smartphone yang menggunakan sistem operasi Android akan lebih murah harganya dibandingkan smartphone yang menggunakan sistem operasi yang berbayar. Fungsi dari sistem operasi itu sendiri bagi smartphone antara lain : 1. Sebagai sarana/jembatan untuk personalisasi smartphone, misal menambahkan aplikasi/game lain lebih baik (banyak) dari yang tanpa sistem operasi.
22 2. Sebagai penyeimbang fitur. Smartphone berfitur super lengkap jika tidak diimbangi sistem operasi yang handal. Fitur-fitur tersebut bisa tidak berjalan mulus (loading yang terlalu lama, mengalami hang, dan sebagainya). 3. Sebagai sarana ber-multitasking. Multitasking adalah suatu fungsi dimana sebuah smartphone bisa menjalankan beberapa aplikasi secara bersamaan dalam waktu yang bersamaan pula. Walaupun ada beberapa smartphone tanpa sistem operasi dapat ber-multitasking, namun tak semaksimal smartphone yang bersistem operasi. 4. Sebagai penentu User Interface (UI) yang digunakan. UI atau antarmuka yang digunakan pun berbeda antar sistem operasi. UI meliputi tampilan, struktur/tata letak menu, animasi, dan sebagainya. Pengguna Android (Android User) biasanya pertama menggunakan Handheld (HH) Android sedikit merasa bingung. Handheld adalah perangkat elektronik mobile yang dapat digenggam yang mempunyai sistem operasi yang lebih kecil dari mikrokomputer yang mempunyai memori yang terbatas seperti PDA (Personal Digital Assistant), handphone dan sebagainya. Setelah memodifikasi barulah merasakan beberapa kecanggihan dari aplikasi yang didukung Android, kemudian mendowload dan menginstall aplikasi yang menurutnya diperlukan. Namun ketika banyak aplikasi yang didownload maka kapasitas memori internal dari handheld tidak mencukupi, dan merasa dibatasi (terbatas) karena keterbatasan memori internal dari perangkat handheld yang digunakan. Masalah seperti itu bisa diselesaikan dengan Android, karena sistem operasi Android adalah Open Source yang bebas dimodifikasi. Caranya adalah dengan rooting, mengupgrade ROM (custom ROM), flashing OS atau modifikasi kernel, karena dengan melakukan custom ROM maka pengguna dapat mengkostumisasi perangkat android sesuai dengan keinginannya.
23 2.7.1 Pengertian ROOT Root itu semacam hak akses tertinggi di dalam sistem android. Ketika pertama kali menggunakan handheld Android yang baru saja dibeli dari toko, kita belum mendapatkan hak akses tersebut. Misal di windows, istilahnya kita hanya sebagai guest, belum jadi administrator. Fungsi kita melakukan root untuk mendapatkan hak akses tertinggi, yaitu seandainya kita mempunyai komputer baru yang sudah diinstall windows namun hanya dapat masuk dan mengakses sebagai guest saja. Hal itu sama ketika menggunakan Android tanpa di-root. Banyak aplikasi-aplikasi penting seperti titanium backup untuk membackup data, shoot me dan drocap untuk print screen halaman, setCPU untuk mengatur clock CPU, dan lain-lain yang tidak dapat dijalankan. Root itu merupakan gerbang awal dari “permainan” berikutnya. Permainan di sini merupakan istilah saat flashing custom rom / OS, overclock CPU, mengganti kernel bawaan, semua gerbangnya dari root itu sendiri. Tanpa root kita tidak dapat melakukan hal-hal tersebut. 2.7.2 Custom ROM Android Android Mod atau yang lebih dikenal dengan istilah Custom ROM Android adalah file sistem firmware perangkat seperti telepon seluler atau tablet pc, yang berbasiskan sistem operasi Android yang dimodifikasi serta dikustomisasi sesuai keinginan (Custom Developer), dengan mengubah firmware resmi dan asli (Stock ROM ) bawaan vendor perangkat tersebut. Tujuan pembuatan custom ROM adalah untuk mengubah atau menambah fitur dari firmware perangkat Android sehingga mempunyai kemampuan, keandalan serta kinerja dan performansi melebihi dari apa yang sudah ditawarkan oleh firmware aslinya. Kemampuan tersebut dapat berupa perbaikan fitur, seperti Wi-Fi, Bluetooth, USB, audio, display, Reboot, Rooted, Network, 3G Modem, kemudahan Install Aplikasi-apps (.apk) dan lain sebagainya, bahkan Over Clock Processor perangkat Android tersebut. Jadi ketika orang menyebutkan custom ROM,
24 sebenarnya itu merupakan modified OS untuk Android yang dibangun oleh kalangan publik secara bebas, karena Android merupakan open source sehingga setiap individu dapat dengan bebas memodifikasi sistem operasi android itu sendiri. 2.7.3 Flashing OS Flashing OS merupakan suatu cara memasukkan data sistem operasi atau menginstall sistem operasi dan kernelnya di dalam handheld android. Caranya hampir sama dengan ketika menginstall ulang komputer. Pertama masuk recovery mode, setelah itu hapus / wipe seluruh data sistem operasi yang lama. Kemudian hapus cache memory dari sistem operasi yang lama, Jadi intinya kita melakukan full wipe, setelah itu baru kita install OS baru / custom ROM. Di dalam clockworkmod recovery semuanya telah tersedia, kita tinggal menggunakan saja. Instalasi OS tersebut yang dimaksud sebagai flashing. Jadi apabila kita mendengar kata flashing, itu sebenarnya adalah instalasi, namun dilakukan lewat recovery. 2.7.4 Modifikasi Kernel Kernel merupakan sistem inti yang menjadi jantung dari sistem operasi. Operasi-operasi yang dijalankan oleh sistem operasi tersebut diproses oleh kernel. Kernel di Android juga bisa dimodifikasi, dan tentunya akan membawa keuntungan bagi sistem operasi atau custom ROM-nya itu sendiri. Biasanya, orang membangun kernel itu disesuaikan dengan custom ROM-nya, tidak bisa seenaknya mengganti kernel dengan kernel lain yang tidak direkomendasikan oleh pembuat custom ROM. Di saat kita mem-flashing custom ROM pada handheld Android, didalam custom ROM itu sendiri sebenarnya sudah tersedia kernel dan terkadang kernel tersebut sudah dimodifikasi. Namun tidak semua handheld menyediakan custom kernel, ada beberapa handheld yang bootloader-nya dikunci oleh perusahaan handheld-nya sehingga kita hanya dapat mengganti sistem operasinya saja, tanpa dapat mengganti kernelnya.
25 2.7.5 Keuntungan dan Kerugian Custom ROM Keuntungan Melakukan Custom ROM a. Peningkatan kinerja dan optimasi pada perangkat, dimana pengguna lebih maksimal menggunakan perangkat Android. b. Memaksimalkan penggunaan memori SD Card eksternal sebagai tempat menyimpan Aplikasi-apps. Biasanya untuk handphone-handphone lama yang masih mempunyai memori internal kecil. c. Beberapa Custom ROM menawarkan fitur yang mengurangi pemborosan baterai. Jadi beterai perangkat bisa lebih irit. d. Ada beberapa Custom ROM yang menawarkan fitur Over Clocking yang terintegrasi , sehingga akses aplikasi perangkat lebih cepat. e. Pengguna memungkinkan untuk root akses ke perangkat serta memudahkan Install Aplikasi tanpa menuju Market Android (sideload apps-aftermarket). Kerugian Melakukan Custom ROM a. Adanya kesulitan-kesulitan yang muncul saat Installasi salah satu Custom ROM, data hilang, file-file sistem korup, beberapa perangkat bahkan tidak bisa booting sama sekali. b. Beberapa Custom ROM malah dapat menjadi masalah pada perangkat anda (bug), maka masuklah forum untuk memperdalam ini. c. Fungsi beberapa bagian perangkat akan hilang atau tidak bisa digunakan setelah menginstall beberapa jenis ROM yang dimodifikasi tersebut, tidak sebelum anda menggunakan firmware asli atau Stock ROM. d. Garansi ponsel/tablet pc akan hilang/batal sejak saat setelah installasi Custom ROM. Jadi tidak perlu khawatir lagi dengan handheld Android yang terbatas kemampuanya, ternyata masih bisa dimodifikasi dan dimaksimalkan kemampuanya. Namun disarankan sebelum melakukan rooting, custom ROM hingga modifikasi kernel sendiri sebaiknya mencari informasi terlebih dahulu melalui internet atau
26 buku-buku, atau dengan berkonsultasi dengan para ahli modifikasi android dan sebaiknya dalam melakunyanya didampingi oleh sang ahli modifikasi agar ketika terjadi kesalahan dalam rooting, atau flashing tidak langsung panik yang membuat kesalahan makin bertambah. Selain itu dapat juga bergabung dengan forum-forum Android user yang ada untuk menambah informasi yang dapat membantu. Jadi manfaatkan Android anda semaksimal mungkin. 2.8 Short Message Service (SMS) SMS adalah suatu fasilitas untuk mengirim dan menerima suatu pesan singkat berupa teks melalui perangkat nirkabel, yaitu perangkat komunikasi telepon selular, dalam hal ini perangkat nirkabel yang digunakan adalah telepon selular. Salah satu kelebihan dari SMS adalah biaya yang murah. Selain itu SMS merupakan metode store dan forward sehingga keuntungan yang didapat adalah pada saat telepon selular penerima tidak dapat dijangkau, dalam arti tidak aktif atau diluar service area, penerima tetap dapat menerima SMS-nya apabila telepon selular tersebut sudah aktif kembali. SMS menyediakan mekanisme untuk mengirimkan pesan singkat dari dan menuju media-media wireless dengan menggunakan sebuah Short Messaging Service Center (SMSC), yang bertindak sebagai sistem yang berfungsi menyimpan dan mengirimkan kembali pesan-pesan singkat [14]. Pada dasarnya semua pesan yang dikirim dengan SMSMT (melalui aplikasi perangkat lunak) dan SMS-MO (melalui telepon seluler) panjang pesan hanya dibatasi pada 160 karakter untuk satu satuan SMS. Hal ini dipengaruhi oleh pemanfaatan ruang sisa pada jalur sinyal GSM. Lebih jelasnya, ruang sisa itu dibatasi sepanjang 140 octets atau 1120 bits. Pembatasan ini telah mencakup proses untuk encoding-decoding dengan standar abjad yang berbeda untuk sistem ponsel atau jaringan yang berbeda. Ukuran standardnya adalah dengan 7 bit alfabet, kemudian mulai dikembangkan standard 8 bit alfabet dan 16 bit UTF-16 alfabet.
27 Maksud dari 7 bit alphabet adalah standard untuk karakter huruf inggris termasuk yang dipakai Indonesia. Panjang karakter maksimal per SMS adalah 160 karakter (semua karakter termasuk spasi). Sedangkan untuk 8 bit, karakter maksimal hanya 140 karakter dan untuk 16 bit alfabet maksimal 70 karakter termasuk pengembangan emoticon. Emoticon yakni karakter khusus yang berbentuk simbol ekspresi atau sering disebut smilies yang merupakan kombinasi dari beberapa karakter. Ada pula karakterkarakter khusus seperti huruf Arab, Jepang, Korea, dan lain-lain yang juga menggunakan tipe standard 16 bit. Standard 16 bit sendiri merupakan karakter Unicode UCS2 yang dapat melakukan proses encoding-decoding. Perkembangan dari segi ukuran lainnya adalah SMS dapat pula menerjemahkan data biner yang merupakan bentuk selain teks seperti nada dering, gambar, logo atau teks untuk operator dan lain-lain yang memanfaatkan sisa 1120 bits ini. Keterbatan karakter SMS ini kemudian memunculkan konsep baru yaitu Long SMS yang memungkinkan untuk dapat mengirimkan pesan singkat panjang namun tetap dengan sisa ruang 1120 bits. Perkembangan ini berhasil memunculkan kekuatan baru SMS namun kapasitas maksimal tiap satuan SMS tetap mengacu pada ketiga standard (7 bits, 8 bits, atau 16 bits). Prosesnya adalah memecah pesan bila lebih dari karakter maksimal melebihi standard. Proses dimulai dengan pengkategorian User data Header berisi informasi segmentasi, kemudian mengirimkannya masing-masing sebagai satu pesan SMS. Setelah sampai di ponsel tujuan, sistem ponsel penerima akan menterjemahkan kembali pecahan Long SMS tersebut menjadi satu SMS, namun kembali lagi pada perbedaan teknologi masing-masing sistem ponsel, jika ponsel penerima hanya menggunakan standard 7 bits, maka satu pesan tersebut tetap diterjemahkan kedalam SMS yang membuat SMS terpecah dan menjadi beberapa pesan teks yang berbeda. Untuk menutupi kekurangan pada SMS maka dikembangkanlah EMS (Enhanced Mesagging Service) yang dapat memuat data biner seperti gambar bergerak (animasi) atau melodi yang
28 sekarang lebih popular Messaging Service) [15].
dengan
sebutan MMS (Multimedia
BAB III METODOLOGI PENELITIAN Pada bab ini diuraikan metodologi penelitian dalam Tugas Akhir ini. Pembahasan metodologi penelitian berguna sebagai acuan sehingga penelitian ini dapat dilakukan secara sistematis. 3.1 Identifikasi Masalah Identifikasi masalah merupakan tahap awal penelitian, dimana pada tahap ini bertujuan untuk mendapatkan dan mempertajam masalah yang selanjutnya akan dibahas dalam penelitian. 3.2 Komparasi Penelitian Terdahulu Pada penelitian sebelumnya algoritma RSA digunakan terkait tentang pengamanan pesan via email. Pengamanan pesan yang dilakukan untuk mengenkripsi email agar terjaga kerahasiaannya saat sampai ke penerima pesan yang dituju. Dari penelitian tersebut penulis mengembangkan algoritma RSA untuk pengamanan pesan via SMS berbasis Android. 3.3 Studi Literatur Pada tahap ini dilakukan studi yang berkaitan dengan permasalahan yang ada. Studi literatur dilakukan terhadap jurnaljurnal ilmiah, tugas akhir, dan buku-buku yang berhubungan dengan kriptografi, Algoritma RSA, pemrograman Android dan Short Message Service (SMS). 3.4 Pengembangan Perangkat Lunak 3.4.1 User Requirement Tahap user requirement akan dijelaskan mengenai langkahlangkah untuk merumuskan kebutuhan pengguna untuk merancang sebuah perangkat lunak yang sesuai dengan kebutuhan dan masalah yang dihadapi.
29
30 3.4.2
Perancangan Perangkat Lunak Perancangan penelitian yang akan dilakukan pada tahap ini antara lain, yaitu: a. Perancangan Flowchart, Data Context Diagram dan Data Flow Diagram b. Perancangan generator bilangan prima. c. Penentuan nilai bitLength pada algoritma RSA. d. Pra-pemrosesan : proses konversi dari huruf menjadi bilangan biner. e. Penerapan fungsi enkripsi dan dekripsi algoritma RSA pada Eclipse IDE. f. Perancangan tampilan aplikasi yang sesuai dengan permasalahan penelitian ini. g. Perancangan aplikasi untuk mengambil kontak telepon bawaan dari Android. h. Perancangan aplikasi agar dapat menerima dan mengirim pesan antar emulator. i. Pengujian aplikasi untuk mengirim dan menerima pesan yang telah terenkripsi. j. Pengujian validitas plaintext sebelum dikirimkan dan setelah dilakukannya proses dekripsi. k. Pengujian response time pada saat melakukan proses enkripsi dan proses dekripsi. 3.5 Implementasi Perangkat Lunak Proses ini merupakan proses perwujudan perancangan yang telah dilakukan ke dalam bentuk interface sistem maupun kodekode program sesuai dengan IDE (Integrated Development Environment) yang dipilih, yaitu Eclipse IDE. IDE adalah program komputer yang memiliki beberapa fasilitas yang diperlukan dalam pembangunan perangkat lunak. Eclipse pada saat ini merupakan salah satu IDE favorit dikarenakan gratis dan open source. Pengertian open source sendiri adalah setiap orang boleh melihat kode pemrograman perangkat lunak ini.
31 3.6 Uji Coba Perangkat Lunak Dalam uji coba ini akan dilakukan proses enkripsi dan dekripsi pesan menggunakan algoritma RSA, kemudian dilanjut untuk mengirim dan menerima pesan yang telah terenkripsi menggunakan dua buah emulator yang selanjutnya akan diterapkan dalam telepon seluler yang sesungguhnya bersistem operasi Android. Pada tahap ini juga akan diuji validitas SMS setelah dilakukan proses enkripsi dan dekripsi apakah sesuai yang diharapkan. Serta menguji response time pada saat melakukan proses enkripsi dan proses dekripsi. 3.7 Penarikan Simpulan dan Saran Pada tahap ini akan dibahas penarikan simpulan mengenai aplikasi pengaman pengiriman pesan via SMS dengan algoritma RSA berbasis Android yang telah dibuat dan saran sebagai masukan untuk pengembangan penelitian lebih lanjut.
32
“ Halaman ini sengaja dikosongkan “
BAB IV ANALISA DAN PERANCANGAN Bab ini akan membahas analisa dan perancangan sistem perangkat lunak yang akan dibangun untuk pengiriman dan penerimaan pesan yang telah terenkripsi dengan menggunakan algoritma RSA pada telepon seluler yang bersistem operasi Android. 4.1 Deskripsi Sistem Banyak fitur-fitur aplikasi yang disediakan oleh Android sebagai sistem operasi telepon seluler seperti pemutaran video, mengakses layanan internet dan sebagainya. Akan tetapi, fiturfitur yang digunakan seperti telepon seluler biasa lainnya yaitu seperti SMS, call, dan MMS masih dapat digunakan pada perangkat lunak berbasis Android tersebut. Dari sekian banyak fitur yang dimiliki oleh Android, salah satunya yang masih banyak digunakan yaitu SMS. SMS digunakan untuk mengirim dan menerima pesan singkat kepada pengguna telepon seluler lainnya. Layanan SMS menggunakan aplikasi SMS bawaan telepon seluler yang masih banyak digunakan oleh setiap orang, bukanlah merupakan jalur yang aman dalam pertukaran informasi. Pesan yang dikirim menggunakan aplikasi SMS bawaan telepon seluler masih berupa teks terbuka yang belum terenkripsi selain itu pengiriman SMS yang dilakukan tidak sampai ke penerima secara langsung, akan tetapi pengiriman SMS harus melewati SMSC yang berfungsi mencatat komunikasi yang terjadi antara pengirim dan penerima. Dengan tersimpannya SMS pada SMSC, seorang operator dapat memperoleh informasi atau membaca SMS di dalam SMSC tersebut, hal ini dapat dibuktikan dari beberapa kasus yang ditangani pihak kepolisian, kejaksaan dan KPK pihakpihak tersebut meminta transkip SMS ke operator GSM untuk dijadikan bahan pembuktian dalam persidangan.
33
34 Dengan demikian dibutuhkan suatu metode dan aplikasi yang dapat mempertimbangkan solusi encrypted end to end dengan melakukan enkripsi terhadap pesan SMS. Enkripsi adalah proses mengubah suatu pesan asli (plaintext) menjadi sebuah sandi atau kode yang tidak terbaca (ciphertext) dan tidak dapat dimengerti. Untuk mengembalikan pesan kebentuk asli seperti semula diperlukan suatu proses yang disebut dekripsi. Enkripsi dimaksudkan untuk melindungi dan menyamarkan informasi agar tidak terlihat oleh pihak atau orang yang bukan seharusnya [16]. Salah satu metode enkripsi yang umum digunakan yaitu asimetris kriptografi. Kunci asimetris adalah pasangan kunci kriptografi yang salah satunya digunakan untuk proses enkripsi dan yang satu lagi untuk proses dekripsi. Semua orang yang mendapatkan kunci publik dapat mengenkripsikan suatu pesan, sedangkan hanya satu orang saja yang memiliki kunci privat untuk melakukan pembongkaran terhadap sandi yang dikirim untuknya. Contoh algoritma kunci asimetris yang terkenal yaitu algoritma RSA yang dirancang oleh Ronald L. Rivest, Adi Shamir dan Leonard M. Adleman pada tahun 1977. Perangkat lunak yang akan dikembangkan merupakan perangkat lunak yang diterapkan pada telepon seluler yang bersistem operasi Android dan memiliki fungsi untuk melakukan enkripsi dan dekripsi. Perangkat lunak juga dapat melakukan pengiriman dan penerimaan pesan. Pengguna akan berinteraksi dengan perangkat lunak, pengguna memasukkan pesan dengan menggunakn keypad yang dimiliki oleh telepon selular. Pesan yang telah dibuat dan terenkripsi dikirimkan ke telepon selular lain melalui jaringan SMS. Secara umum arsitektur global perangkat lunak dapat dilihat pada Gambar 4.1 berikut. SMS Dikirim
SMS Diterima Jaringan SMS
Pengirim Penerima Gambar 4.1 Pengiriman dan Penerimaan SMS
35 Hal-hal yang dapat dilakukan oleh pengguna terhadap sistem dapat dilihat pada diagram use case pada Gambar 4.2 berikut. Tulis Pesan Enkripsi Terima Pesan Dekripsi Pengirim
Penerima Akses Inbox Akses About
Gambar 4.2 Use Case Diagram System Proses-proses use case diagram system pada gambar diatas akan dijelaskan dibawah ini : 1. Tulis Pesan Pengirim menulis pesan pada aplikasi untuk dikirim ke nomor tujuan yang diinginkan. 2. Enkripsi Pengirim mengenkripsi pesan yang akan dikirim agar pesan tersandikan dan tidak dapat dibaca oleh orang lain yang tidak mempunyai kunci untuk membukanya. 3. Akses Inbox Pengirim / penerima dapat melihat dan membaca pesan di dalam kotak masuk pada perangkat lunak ini dengan memilih pesan masuk yang diinginkan. 4. Terima Pesan Penerima mendapatkan pesan dari pengirim berupa pesan yang telah disandikan.
36 5. Dekripsi Penerima mendekripsi pesan yang tersandikan agar dapat terbaca. 6. Akses About Penerima / pengirim mendapat keterangan mengenai aplikasi seperti versi dan pembuat aplikasi. 4.2 Analisa Sistem Analisa sistem adalah teknik pemecahan masalah yang menguraikan bagian-bagian komponen dengan mempelajari seberapa bagus komponen-komponen tersebut bekerja dan berinteraksi untuk mencapai tujuan mereka [17]. Analisa merupakan tahapan awal dan sangat penting, karena kesalahan pada tahap ini akan menyebabkan kesalahan pada tahap selanjutnya. Analisa merupakan fondasi untuk menentukan sukses atau tidaknya suatu sistem yang akan dibuat. Dalam perancangan sistem nantinya hal yang sangat penting adalah dengan mengetahui masalah yang timbul dan kebutuhan yang yang dibutuhkan. 4.2.1
Analisa Kebutuhan Pada tahap analisa kebutuhan dilakukan pengumpulan informasi proses pengiriman pesan yang telah dienkripsi oleh algoritma RSA dan daftar kebutuhan user secara lengkap. Hal ini dapat diperoleh dengan menyusun scope of work software yang akan dibuat beserta perangkat lunak yang dibutuhkan. Pada penelitian ini, scope of work software yang dibuat meliputi : a. Proses pembangkitan kunci publik dan kunci privat. b. Proses enkripsi dan dekripsi dengan algoritma RSA. c. Proses transformasi karakter kedalam kode ASCII dan sebaliknya. d. Proses penyimpanan hasil enkripsi dan nomor telepon pengirim yang akan dikirim. e. Proses pengiriman dan penerimaan SMS.
37 f.
Proses verifikasi SMS ketika SMS telah diterima. Sedangkan kebutuhan perangkat lunak yang dibutuhkan pada penelitian ini adalah yang memiliki kemampuan sebagai berikut : a. Dapat melakukan proses komputasi dengan cepat, termasuk penanganan input dan output. b. Memiliki tingkat ketelitian yang tinggi. c. Memiliki beberapa fasilitas yang diperlukan dalam pembangunan perangkat lunak, khususnya yang bersistem operasi Android seperti mengambil kontak dan SMS masuk dari bawaan Android serta mengirim dan menerima SMS. Dari kebutuhan tersebut Eclipse IDE dapat memenuhi semua kriteria, sehingga dapat digunakan untuk membangun sistem pada penelitian ini.
Software Requirement Spesification (SRS) Spesifikasi kebutuhan perangkat lunak yang akan dikembangkan di Pengaman SMS dapat dilihat di Tabel 4.1 berikut: Tabel 4.1 Spesifikasi kebutuhan perangkat lunak No SRS ID Deskripsi Menerima masukan berupa No. Tujuan dan 1 SRS - 1 pesan asli Mengenkripsi pesan menggunakan algoritma 2 SRS - 2 RSA Mengirimkan pesan dan memberikan laporan 3 SRS - 3 kepada pengirim bahwa pesan yang telah dienkripsi sudah dikirim ke Nomor Tujuan Memberikan Nomor Pengirim dan ciphertext 4 SRS - 4 kepada penerima Mendekripsi ciphertext menggunakan kunci 5 SRS - 5 yang telah dimasukkan Menampilkan pesan asli yang telah di dekripsi 6 SRS - 6 kepada penerima 4.2.2
38 4.2.3
Analisa Algoritma RSA sebagai Kunci Publik Cryptosystem Algoritma RSA adalah sebuah algoritma penyandian data yang termasuk dalam kunci publik cryptosystem yang memerlukan sepasang kunci untuk setiap usernya, kunci tersebut adalah kunci publik dan kunci privat. Kunci publik boleh diketahui umum yang digunakan untuk proses pengenkripsian data. Sedangkan kunci privat adalah kunci rahasia yang tidak boleh diketahui oleh pihak lain selain user pemiliknya. Seperti yang dijelaskan pada Sub Bab 2.5, proses pembentukan kunci pada Algoritma RSA akan menghasilkan kunci publik (e,n) dan kunci privat (d) dimana e sebagai public exponent dan d sebagai private exponent. Dengan algoritma RSA, enkripsi mampu disajikan hanya dengan satu algoritma. Proses enkripsi adalah perhitungan c = me mod n dengan e sebagai public exponent dan proses dekripsi merupakan perhitungan m = cd mod n dengan d sebagai private exponent. Keamanan algoritma RSA terletak pada tingkat kesulitan dalam memfaktorkan bilangan non-prima menjadi faktor primanya, yang dalam hal ini n = p . q. Sekali n berhasil difaktorkan menjadi p dan q maka ϕn = (p-1)(q-1) dapat dihitung. Jika algoritma pemfaktoran ini ditemukan maka dengan sangat mudah kunci privat yang merupakan pasangan kunci publik milik user bisa diketahui. Penemu algoritma RSA menyarankan agar panjang nilai p dan q lebih dari 100 digit. Dengan demikian hasil kali n = p . q akan lebih dari 200 digit. Menurut Rivest dan kawan-kawan, usaha untuk mencari faktor bilangan 200 digit membutuhkan waktu komputasi selama 4 milyar tahun (dengan asumsi bahwa algoritma pemfaktoran yang digunakan adalah algoritma yang tercepat saat ini dan komputer yang dipakai mempunyai kecepatan 1 milidetik). Inilah yang membuat algoritma RSA tetap direkomendasikan untuk digunakan dalam penyandian pesan selagi belum ditemukan algoritma yang mampu untuk memfaktorkan bilangan bulat menjadi faktor primanya.
39 4.2.4
Analisa Perancangan Perangkat Lunak Perangkat lunak pengaman SMS dalam tugas akhir ini dibuat menurut algoritma RSA, mulai dari pembentukan kunci, enkripsi dan dekripsi. Serangan pematahan algoritma RSA pada program pengamanan data ini mungkin dilakukan dengan memanfaatkan persamaan e.d = 1 mod ϕ(n) atau e.d = k.ϕ(n)+1. Jika seorang hacker masuk sebagai user dan mendapat kunci privat d maka hacker tersebut dapat menghitung nilai ϕ(n) sehingga secara logika nilai kunci privat user lainnya bisa dihitung dari nilai kunci publik masing-masing user. 4.3 Perancangan Perangkat Lunak 4.3.1 Perancangan Flowchart Perangkat Lunak Perancangan ini ditujukan untuk mempermudah pembuatan program. Dalam penelitian ini flowchart dibuat untuk mengetahui langkah-langkah apa saja yang harus diterapkan, agar sistem yang dibuat dapat menghasilkan keluaran yang sesuai dengan harapan berupa hasil dari proses enkripsi dan dekripsi. Pengirim Penerima Mulai Input Plainteks Enkripsi Pesan dan mengirim hasil enkripsi Bangkitkan Kunci
Menerima Kunci Privat, Modulus Ciphertext dan No Pengirim Dekripsi Pesan Plainteks Selesai
Kunci Publik Kunci Privat Modulus Ciphertext
Gambar 4.3 Flowchart Perangkat Lunak
40 Skenario berjalannya flowchart perangkat lunak pada Gambar 4.3 adalah sebagai berikut : 1. Mulai menjalankan sistem. 2. Langkah awal dari perancangan sistem adalah pengirim melakukan proses masukan pesan asli yang akan disandikan. 3. Kemudian dilakukan proses enkripsi pesan. Pada proses enkripsi akan melakukan proses bangkitkan kunci yang keluarannya adalah kunci publik, kunci privat, modulus dan pesan yang telah terenkripsi menjadi ciphertext. Setelah proses bangkitkan kunci, pengirim pesan mengirimkan hasil enkripsi kepada penerima pesan. 4. Penerima menerima ciphertext dari pengirim. 5. Kemudian dilakukan proses dekripsi yang keluarannya adalah pesan asli (plaintext) 6. Sistem telah selesai dijalankan. 4.3.2
Perancangan Data Context Diagram Pendefinisian dengan Data Context Diagram (DCD) atau DFD level 0 memberikan data yang mengalir antara sistem dengan lingkungan yang digambarkan secara global.
Gambar 4.4 DCD Aplikasi Pengaman SMS Pada Gambar 4.4 menjelaskan bahwa pengirim memasukkan plaintext dan nomor tujuan kepada sistem. Sistem memberikan keluaran berupa laporan pesan terkirim kepada pengirim. Penerima memasukkan ciphertext kepada sistem dan sistem memberikan keluaran berupa plaintext kepada penerima.
41 4.3.3
Perancangan Data Flow Diagram Data Flow Diagram (DFD) adalah representasi grafik dari sebuah sistem. DFD menggambarkan komponenkomponen sebuah sistem, aliran-aliran data di mana komponen-komponen tersebut, dan asal, tujuan, dan penyimpanan dari data tersebut. 4.3.3.1 DFD Level 1
Gambar 4.5 DFD level 1 Gambar 4.5 merupakan DFD level 1 dari aplikasi perangkat lunak Pengaman SMS. Pada DFD level 1, sistem akan dipecah menjadi proses-proses kecil sehingga dapat menjelaskan prosesproses dan arus data yang mengalir dalam sistem. Proses-proses yang terdapat dalam DFD level 1 adalah: 1. Input Plaintext dan Nomor Pengirim Pengirim memasukkan pesan asli (plaintext) dan nomor tujuan ke dalam sistem. 2. Tulis Pesan
42 Dalam proses tulis pesan ini akan dilakukan pengenkripsian pesan dengan algoritma enkripsi RSA. 3. Pengiriman pesan Proses ini melakukan pengiriman pesan yang telah dienkripsi serta memberikan laporan pengiriman kepada pengirim bahwa pesan telah dikirimkan ke nomor yang telah dimasukkan. 4. Baca Pesan Proses ini melakukan pendekripsian pesan. Apabila kunci benar maka ciphertext akan menjadi pesan asli. Jika kunci salah pesan akan tetap didekripsi akan tetapi pesan yang didapat bukan pesan asli. 4.3.3.2 DFD Level 2 Proses Enkripsi
Gambar 4.6 DFD level 2 Proses Enkripsi Proses-proses yang terdapat dalam DFD level 2 pada proses enkripsi pada Gambar 4.6 adalah sebagai berikut. 1. Transformasi karakter ke kode ASCII Proses ini melakukan transformasi pesan asli (plaintext) ke dalam kode ASCII. 2. Enkripsi Setelah pesan ditransformasikan ke dalam kode ASCII, proses selanjutnya adalah melakukan pengenkripsian pesan dengan metode enkripsi RSA yang akan menghasilkan kunci
43 privat, modulus dan ciphertext yang akan dikirimkan ke penerima pesan. 3. Pengiriman pesan Sistem akan mengirimkan hasil enkripsi serta memberikan laporan pengiriman kepada pengirim bahwa pesan telah dikirimkan. 4.3.3.3 DFD Level 2 Proses Dekripsi
Gambar 4.7 DFD level 2 Proses Dekripsi Gambar 4.7 adalah DFD level 2 proses dekripsi pesan yang dapat dijelaskan sebagai berikut. 1. List Inbox Penerima akan menerima nomor pengirim ciphertext yang telah dikirimkan oleh pengirim di dalam list inbox. 2. Dekripsi Setelah kita memilih pesan pada list inbox, kemudian akan dilakukan pemanggilan class baca() untuk melakukan proses dekripsi pesan.
44 3. Transformasi ASCII ke karakter Proses ini melakukan transformasi pesan ASCII yang selesai didekripsi yang kemudian dikembalikan kedalam bentuk karakter atau pesan asli. 4.4 Perancangan Proses dari Perangkat Lunak 4.4.1 Penggunaan Kelas BigInteger Jika presisi bilangan bulat (Long) dan floating point sudah tidak memadai, dapat menggunakan kelas BigInteger untuk dapat melakukan operasi aritmatika untuk bilangan bulat yang sangat besar sehingga kelas ini sering dipakai dalam aplikasi kriptografi yang melibatkan ratusan bahkan ribuan bit. Pada algoritma RSA, terdapat beberapa besaran yang digunakan. Besaran-besaran tersebut merupakan variabel atau objek dari kelas BigInteger. Karena dalam kelas BigInteger sudah mempunyai metode-metode khusus dalam kriptografi maka dapat mempermudah dalam proses perancangan. 4.4.2
Pembuatan Generator Bilangan Prima Algoritma RSA memerlukan dua bilangan prima p dan q untuk pembentukan kunci. Oleh karena itu diperlukan sebuah program untuk menentukan bilangan prima. Dalam tugas akhir ini penulis menggunakan angka acak / random yang digunakan untuk memudahkan user agar tidak perlu menginput p dan q secara manual, tetapi secara otomatis. Penggunaan bilangan prima jauh mempermudah proses perhitungan Φ(n) untuk n = p . q dimana p dan q bilangan prima bila dibandingkan dengan proses perhitungan Φ(n) untuk sembarang bilangan bulat positif n. Hal ini dikarenakan apabila menggunakan bilangan prima maka Φ(n) dapat dengan mudah dihitung menggunakan Fungsi Euler dan Teorema Fermat menjadi Φ(n) = (p - 1)(q - 1) dan tentunya persamaan ini tidak akan dapat dipenuhi jika salah satu dari p atau q tidak prima karena menyebabkan Φ(p) < (p - 1) atau Φ(q) < (q - 1).
45 4.4.3
Pembentukan Kunci Publik dan Kunci Privat dengan Algoritma RSA Setelah proses pembentukan bilangan prima dilakukan maka dipilih dua buah bilangan prima yang cukup besar dengan selisih keduanya relatif kecil. Hitung modulus n dari perkalian p dan q. Selanjutnya p dan q akan terus digunakan sebagai bilangan prima pembentuk kunci publik dan kunci privat. Dengan kata lain, proses pemilihan dua bilangan prima sebagai pembentuk kunci publik dan kunci privat hanya dilakukan sekali saja namun tidak menutup kemungkinan suatu saat nilai p dan q harus diubah demi pembaharuan sistem pengaman data pada aplikasi ini. Dengan p dan q yang sama maka modulus n yang digunakan pada setiap pembentukan e pada kunci publik dan kunci privat d berikut adalah sama. Selain pada proses ini, modulus n juga diperlukan pada proses lain seperti enkripsi dan dekripsi. Namun seiring perkembangan teknologi dan peningkatan kecepatan komputer, memunculkan anjuran pemakaian kunci yang lebih panjang. Pada tahun 1992, RSA Coding yang menggunakan kunci 512 digit dapat dipecahkan dalam waktu 7 bulan. Lebih dianjurkan untuk menggunakan ukuran kunci 1024 bit untuk hal yang berhubungan dengan hukum dan 2048 bit untuk kunci-kunci yang ekstrem, seperti kunci yang digunakan oleh alat untuk verfikasi wewenang. Beberapa standar pada saat ini lebih menganjurkan 1024 bit untuk penggunaan dalam bidang hukum. Informasi yang lebih tidak terlalu penting sudah cukup dienkripsi dengan kunci 768 bit. 4.4.4
Proses Enkripsi dengan Algoritma RSA Inti dari proses enkripsi adalah perhitungan c = me mod n dimana c, m dan n dalam bilangan bulat positif dan e yang telah direpresentasikan dalam biner. Untuk mencapai bentuk bilanganbilangan yang diperlukan dalam perhitungan tersebut dibuatlah proses pendukung. Proses pendukung itu adalah proses pengubahan tiap karakter pesan dari bentuk text kedalam bentuk bilangan bulat positif. Setelah proses perhitungan c = me mod n
46 dengan bentuk bilangan yang telah terpenuhi maka proses enkripsi dengan algoritma RSA dapat dijalankan. Algoritma 8.2 Enkripsi RSA Input Kpublik = (e,n), m
Zn
Output c = me mod n. 4.4.5
Proses Dekripsi dengan Algoritma RSA Dalam proses dekripsi yang menjadi intinya adalah perhitungan m = cd mod n dimana c, m dan n dalam bilangan bulat positif dan d yang telah direpresentasikan dalam bentuk biner. Proses yang digunakan dalam proses deskripsi adalah mengembalikan nilai m yang semula dalam bentuk bilangan bulat (ciphertext) menjadi m ke bentuk text (plaintext). Dengan kata lain proses ini adalah invers dari proses enkripsi. Algoritma 8.2 Dekripsi RSA Input Kprivat = d, Kpublik = (e,n), c
Zn
Output m = cd mod n. 4.4.6
Perancangan Proses Pengiriman Pesan Maksud dari pengiriman pesan disini adalah pengiriman pesan kepada seseorang melalui sebuah jaringan telepon selular. Pengiriman pesan dapat berupa pesan yang sudah terenkripsi atau pun pesan biasa yang tanpa melalui perubahan kode enkripsi. Apabila akan mengirim pesan pada aplikasi ini yang pertama kali dilakukan adalah menulis pesan yang ingin disandikan, kemudian setelah melakukan proses enkripsi user akan melakukan pengiriman pesan yang telah disandikan serta mengirimkan kunci D dan kunci N (kunci D dan kunci N berfungsi untuk menterjemahkan pesan yang disandikan menjadi pesan yang dapat dibaca oleh manusia).
47 Proses pengiriman pesan ini sebenarnya tidak terkait langsung dengan algoritma RSA, hanya sebagai jembatan untuk mengirimkan pesan yang dibuat. Adapun teknologi yang digunakan oleh pengirim pesan ini adalah teknologi SMS yang berfungsi untuk mengirimkan pesan pada suatu jaringan, dalam hal ini adalah jaringan telepon. 4.4.7
Perancangan Proses Penerimaan Pesan Sama halnya seperti pengiriman pesan, penerimaan pesan ini berfungsi untuk menerima pesan yang dalam hal ini berbentuk SMS. Pada saat adanya pesan sandi yang masuk, maka terdapat list-list pesan dalam bentuk ListView atau Array. Kemudian setelah pesan yang diterima masuk kedalam Inbox maka langkah selanjutnya akan dilakukan proses deskripsi untuk menampilkan pesan yang tersandikan oleh proses enkripsi yang kemudian dijadikan pesan asli setelah memasukkan kuncikunci yang diperlukan. 4.5 Perancangan Tampilan Perangkat Lunak Perancangan tampilan merupakan tahap yang juga sangat penting selain perancangan proses pada pembuatan aplikasi. Pada perancangan tampilan ini akan dibahas satu persatu tampilan yang akan dibuat untuk mendukung perancangan proses yang telah dibahas sebelumnya, pembahasan akan dilakukan satu persatu berdasarkan layout yang dibuat pada Eclipse IDE. Pembahasan akan dijelaskan secara terurut dari layout awal saat aplikasi dijalankan, proses enkripsi dan proses dekripsi, pengambilan kotak masuk dari inbox bawaan Android hingga layout akhir, kecuali untuk layout About yang hanya berisi tentang informasi aplikasi ini, tidak akan dibahas karena tidak begitu penting. Diagram alur aplikasi Pengaman SMS dapat dilihat pada Gambar 4.8 berikut.
48
Gambar 4.8 Flowchart Aplikasi Pengaman SMS 4.5.1 Tampilan Layout Main Layout Main merupakan layout utama dari perangkat lunak Pengaman SMS ini, pada form ini terdapat beberapa tombol utama yang menghubungkan ke fungsi-fungsi editor yang tersedia, seperti Tulis Pesan, Baca Pesan dan About. Tombol Tulis Pesan berfungsi untuk mengenkripsi pesan dan tombol Baca Pesan berfungsi untuk menampilkan list pesan dan membaca pesan yang telah terenkripsi, kemudian mendekripsinya kembali agar pesan asli bisa diketahui oleh penerima pesan.
49 Tombol About berfungsi untuk menampilkan tentang pembuat aplikasi dan versi dari aplikasi ini. Pada Gambar 4.9 merupakan tampilan awal dari aplikasi Pengaman SMS.
Gambar 4.9 Rancangan Tampilan untuk Layout Main 4.5.2 Tampilan Layout Tulis Pesan Layout ini merupakan tampilan yang menampilkan layout yang berfungsi untuk menulis, mengirim dan mengenkripsi pesan. Jika ingin menulis pesan maka textbox-textbox yang ada harus terisi sesuai dengan field-field yang ada. Tombol Kirim Pesan yang berada di bawah sendiri berfungsi untuk menjalankan proses enkripsi dan menampilkan hasil dari pesan yang telah di enkripsi beserta kunci-kuncinya serta untuk mengirimkan pesan yang telah tersandikan kepada pengirim yang dituju oleh pengguna. Untuk tampilannya seperti Gambar 4.10 berikut.
50
Gambar 4.10 Tampilan Layout Tulis Pesan 4.5.3 Tampilan Layout Inbox Pada layout Inbox berfungsi untuk menampilkan SMS yang ter-update dan menampilkannya dalam list pesan yang nantinya akan digunakan untuk melakukan proses dekripsi pesan. List dalam proses ini bersifat array, dan aplikasi ini menggunakan array yang berasal dari bawaan android bukan array pada umumnya. Terdapat satu fungsi untuk memanggil pesan yang berada pada inbox bawaan dari Android kemudian akan ditampilkan di list pesan pada aplikasi Pengaman SMS ini. Gambar 4.11 merupakan tampilan dari Layout Inbox.
51
Gambar 4.11 Tampilan Layout Inbox 4.5.4 Tampilan Layout Baca Pesan Pada tampilan Baca Pesan ini terdapat beberapa textfield yang harus diisi pengguna agar pesan yang disandikan dapat dibaca oleh penerima, textfield yang harus diisi pengguna adalah memasukkan kunci d dan kunci n (modulus) untuk melakukan proses dekripsi pesan. Untuk nomor telepon pengirim dan pesan yang terenkripsi secara otomatis diambil dari list pesan yang berada pada layout Inbox. Setelah pengguna atau penerima pesan menekan tombol terjemahkan yang berupa gambar gembok terbuka maka proses dekripsi untuk mendapatkan pesan asli akan dimulai. Kemudian hasil atau pesan aslinya akan ditampilkan pada textfield hasil yang berada dibawah tombol terjemahkan. Rancangan tampilan dari layout baca pesan seperti gambar 4.12 berikut.
52
Gambar 4.12 Tampilan Layout Baca Pesan
BAB V PEMBAHASAN DAN PENGUJIAN Pada pembahasan kali ini akan ditunjukkan bagaimana pembahasan implementasi dari rancangan yang telah dibahas pada bab sebelumnya. Pada bab ini juga akan ditunjukkan bagaimana cara kerja dari perangkat dengan menguji cobanya sehingga dapat memenuhi tujuan yang ingin dicapai pada pembuatan tugas akhir ini, yaitu pengamanan pesan SMS dengan algoritma RSA sehingga pengiriman atau penerimaan pesan dapat terjaga kerahasiaannya. 5.1 Pembahasan Aplikasi Pengaman SMS dengan Algoritma RSA Adapun aplikasi yang penulis buat dibuat di perangkat lunak Eclipse IDE dengan spesifikasi komputer antara lain: 1. logo laptop adalah acer aspire 4741 2. Sistem Operasinya memakai windows 8 32bit, dan 3. Installed Memory (RAM) 2 GB. 4. Harddisk 500 GB Rincian dari aplikasi ini meliputi : 1. Nama Aplikasi : PengamanSMS 2. Android_version : 2.3 ke atas dapat menggunakan aplikasi ini. 3. Jumlah emulator yang digunakan dalam tahap ini adalah dua emulator yang meliputi emulator pertama dengan nomor 5554 dan emulator kedua dengan nomor 5556. 4. Aplikasi diuji di selular android : Lenovo A390 dan Samsung Galaxy Ace 3. Dalam proses aplikasi ini terdapat tiga proses , meliputi : 1. Proses mengirimkan pesan yang telah terenkripsi 2. Proses pembuatan inbox yang dibuat dalam bentuk list array 3. Proses melakukan enkripsi SMS dan dekripsi SMS 53
54 Proses koding aplikasi ini terdiri dari 6 class meliputi class Secure() , class tulis() , class RSA() , class inboxsms() , class baca(), class about(). Dalam pembuatan masing – masing class terdapat banyak fungsi yang akan dijelaskan dalam pembahasan ini. 5.1.1
Pembahasan Tampilan Layout Main
Gambar 5.1 Tampilan Awal Pada tampian awal pada Gambar 5.1 ini dijalankan dengan emulator Android yaitu Eclipse IDE dan merupakan awal mula dalam menjalanan proses aplikasi. Pada tampilan awal aplikasi mempunyai tiga buah pilihan yaitu “Tulis Pesan”, “Baca Pesan” dan “About”. Fungsi dari masing – masing pilihan ini meliputi : 1. Tulis Pesan => pilihan ini merupakan awal mula dalam melakukan proses pengiriman pesan dari pesan yang akan di enkripsi.
55
=> pilihan ini dipakai saat adanya pesan 2. Baca Pesan sandi yang masuk , maka saat pilihan ini dipilih terdapat list – list pesan dalam bentuk ListView. 3. About => saat pilihan ini dipilih maka akan muncul keterangan mengenai aplikasi ini. Adapun koding java tampilan awal ini ditempatkan di class Secure() yang isinya meliputi : public class Secure extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_secure); //ke menu tulis pesan Button write=(Button)findViewById(R.id.tulissms); write.setOnClickListener(new View.OnClickListener(){ public void onClick(View v){ Intent create=new Intent(getApplicationContext(), tulis.class); startActivity(create); } }); //ke menu inbox Button read=(Button)findViewById(R.id.bacasms); read.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { Intent list=new Intent(getApplicationContext(), inboxsms.class); startActivity(list); } }); // ke menu about Button ttg=(Button)findViewById(R.id.tentang); ttg.setOnClickListener(new View.OnClickListener(){ public void onClick(View v){ Intent tentang=new Intent(getApplicationContext(), about.class); startActivity(tentang); } }); }
56 Adapun dari penjelasan koding diatas meliputi : setContentView(R.layout.activity_secure);
Koding diatas merupakan langkah awal dalam proses class ini karena memiliki fungsi memanggil tampilan design pada tampilan awal aplikasi dalam format main.xml (segala tampilan aplikasi berfomat xml dan dipanggil ke koding java dengan sintak koding ini). Button write=(Button)findViewById(R.id.tulissms);
Sintak ini mendeklarasikan tombol button “Tulis Pesan” yang nantinya jika di klik , akan memanggil class tulis. Cara dalam melakukan pemanggilan class yaitu dengan sintak di bawah ini. Intent create=new Intent(getApplicationContext(), tulis.class);
Sama halnya dengan button “Baca Pesan” dan “About”. Sintak untuk memanggil class inbox dan class about dengan menggunakan sintak. Intent list=new Intent(getApplicationContext(), inboxsms.class); Dan Intent tentang=new Intent(getApplicationContext(), about.class);
Sedangkan untuk sintak menjalankan kegunaan dari button.
dibawah
berfungi
untuk
write.setOnClickListener(new View.OnClickListener(){ public void onClick(View v){ read.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { ttg.setOnClickListener(new View.OnClickListener(){ public void onClick(View v){
57 Untuk proses dengan alur flowchart dapat digambarkan pada Gambar 5.2 sebagai berikut :
Gambar 5.2 Flowchart Pemanggilan Class
58 5.1.2
Pembahasan Tampilan Layout Tulis Pesan Dalam tahap ini, disaat pengguna memilih menu “Tulis Pesan” maka tampilan awal dari aplikasi akan memanggil class tulis(). Tampilan dari Tulis Pesan diberikan oleh Gambar 5.3 berikut.
Gambar 5.3 Tampilan Tulis Pesan Pengirim dapat memasukkan nomor telepon secara manual dan terdapat juga tombol Add Contact yang berfungsi mengambil kontak atau nomor telepon secara otomatis ke kontak bawaan Android. Jadi pengirim dapat memilih penerima yang diinginkan yang berada pada kontak bawaan Android. Adapun button kirim pesan akan berfungsi untuk mengenkripsi pesan yang telah dimasukkan oleh pengirim pesan dan mengirimkan hasil pesan yang sudah dienkripsi dimana pesan yang sudah terenkripsi akan ditampilkan di textfield hasil. Dalam tampilan ini, class yang digunakan adalah class tulis() yang mempunyai beberapa function yaitu seperti pada gambar 5.4 berikut ini.
59
Gambar 5.4 Function pada class tulis() Dalam function kirimSMS() mempunyai fungsi yang bertugas untuk mengirimkan pesan yang telah dienkripsi dan mengirim nomor telepon pengirim kepada penerima pesan. Jadi penerima pesan hanya mendapatkan nomor telepon pengirim dan pesan yang telah dienkripsi pada list Inbox yang berada pada aplikasi Pengaman SMS. Berikut isi dari function kirimSMS() ini yaitu : kirim.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { String notelp = phone_no.getText().toString().trim(); long startTime = System.currentTimeMillis(); String plain = pesan.getText().toString().trim(); chipertext=new StringBuilder(); RSA rsa = new RSA(); if(notelp.length()>0 && plain.length()>0){ sentPI = null; deliveredPI = null; chipertext=new StringBuilder(); rsa.generateRSAKeys(rsa.getKeyLength()); String plaintext=pesan.getText().toString().trim(); char[] huruf=plaintext.toCharArray(); for(int i=0;i
60 String pesan_chiper = rsa.getD().toString()+"-"+ rsa.getN().toString()+"."+chipertext; kirimSMS(notelp, pesan_chiper); } else if(notelp.length()==0 && plain.length()>0){ Toast.makeText(getBaseContext(),"no HP tidak boleh kosong", Toast.LENGTH_LONG).show(); } else if(plain.length()==0 && notelp.length()>0) { Toast.makeText(getBaseContext(),"Pesan tidak boleh kosong", Toast.LENGTH_LONG).show(); } else if(plain.length()==0 && notelp.length()==0) { Toast.makeText(getBaseContext(),"Pesan dan no HP tidak boleh kosong", Toast.LENGTH_LONG).show(); } long endTime = System.currentTimeMillis(); System.out.println("It took " + (endTime - startTime) + " milliseconds"); } });
Function kirimSMS() didukung oleh sintak berikut yang merupakan bawaan dari Android itu sendiri untuk mengirimkan pesan. Berikut sintaknya. mybroadcast=new BroadcastReceiver() { @Override public void onReceive(Context arg0,Intent arg1) { switch(getResultCode()) { case Activity.RESULT_OK: Toast.makeText(getBaseContext(),"SMS Terkirim", Toast.LENGTH_SHORT).show(); break; case Activity.RESULT_CANCELED: Toast.makeText(getBaseContext(),"SMS not delivered", Toast.LENGTH_SHORT).show(); break; case SmsManager.RESULT_ERROR_GENERIC_FAILURE: Toast.makeText(getBaseContext(),"Generic failure", Toast.LENGTH_SHORT).show(); break; case SmsManager.RESULT_ERROR_NO_SERVICE: Toast.makeText(getBaseContext(),"No Service",
61 Toast.LENGTH_SHORT).show(); break; case SmsManager.RESULT_ERROR_NULL_PDU: Toast.makeText(getBaseContext(),"Null PDU", Toast.LENGTH_SHORT).show(); break; case SmsManager.RESULT_ERROR_RADIO_OFF: Toast.makeText(getBaseContext(),"Radio Off", Toast.LENGTH_SHORT).show(); break; } } }; registerReceiver(mybroadcast,new IntentFilter("SMS_SENT"));
Dalam function kirimSMS() terdapat parameter yakni String noTelp dan String pesan_chiper seperti dibawah ini. public void kirimSMS(String noTelp , String pesan_chiper)
Parameter ini akan memudahkan aplikasi dalam melakukan proses pengiriman nomor telepon pengirim dan pesan yang telah terenkripsi. Sedangkan untuk parameter String noTelp, String d_key dan String N_key pada function kirimKEY() memudahkan untuk pengiriman kunci seperti dibawah ini. public void kirimKEY(String noTelp , String d_key, String N_key)
Untuk function selanjutnya merupakan function main() yang bertugas sebagai proses jalannya pengiriman pesan yang disandikan berikut juga nomor telepon pengirim. Isi koding dari function main adalah sebagai berikut. public void onCreate(Bundle savedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.tulis); kirim = (Button)findViewById(R.id.kirim); phone_no = (EditText)findViewById(R.id.NoTujuan); pesan = (EditText)findViewById(R.id.pesan); hasil = (EditText)findViewById(R.id.hasil); e = (EditText)findViewById(R.id.e); d = (EditText)findViewById(R.id.d); N = (EditText)findViewById(R.id.modulus); contact=(Button) findViewById(R.id.kontak);
62
//ambil kontak telp contact.setOnClickListener(new View.OnClickListener(){ @Override public void onClick(View v) { kontak(); } private void kontak() { Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI); startActivityForResult(intent, RQS_PICK_CONTACT); } }); kirim.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { String notelp = phone_no.getText().toString().trim(); long startTime = System.currentTimeMillis(); String plain = pesan.getText().toString().trim(); chipertext=new StringBuilder(); RSA
rsa = new RSA();
if(notelp.length()>0 && plain.length()>0){ sentPI = null; deliveredPI = null; chipertext=new StringBuilder(); rsa.generateRSAKeys(rsa.getKeyLength()); String plaintext=pesan.getText().toString().trim(); char[] huruf=plaintext.toCharArray(); for(int i=0;i
63 else if(notelp.length()==0 && plain.length()>0){ Toast.makeText(getBaseContext(),"no HP tidak boleh kosong", Toast.LENGTH_LONG).show(); } else if(plain.length()==0 && notelp.length()>0) { Toast.makeText(getBaseContext(),"Pesan tidak boleh kosong", Toast.LENGTH_LONG).show(); } else if(plain.length()==0 && notelp.length()==0) { Toast.makeText(getBaseContext(),"Pesan dan no HP tidak boleh kosong", Toast.LENGTH_LONG).show(); } long endTime = System.currentTimeMillis(); System.out.println("It took " + (endTime - startTime) + " milliseconds"); } }); }
Function dari main yang sudah dijelaskan ini mempunyai dua tugas , yang dimana tugas pertama adalah mengambil kontak dari list kontak yang sudah ada pada Android, tugas kedua adalah enkripsi pesan dan mengirimkan pesan yang sudah dienkripsi. Untuk pengambilan kontak yang ada pada Android secara otomatis dengan menggunakan sintak dibawah ini. contact.setOnClickListener(new View.OnClickListener(){ public void onClick(View v) { kontak(); } private void kontak() { Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI); startActivityForResult(intent, RQS_PICK_CONTACT); } });
Tugas kedua function main() dalam proses melakukan enkripsi yang pertama kali dilakukan adalah memanggil class RSA() dengan cara menuliskan sintak. RSA
rsa = new RSA();
64 Untuk proses enkripsi dan dekripsi yang dipanggil dari class RSA() menggunakan function parameter yang terdiri dari parameter pesan yang akan disandikan , parameter kunci D, kunci E dan kunci N. Untuk isi koding dari class RSA() yang berfungsi untuk melakukan proses penyandian pesan (enkripsi) dan menterjemahkan pesan (dekripsi) adalah sebagai berikut. public class RSA { //encrypt public BigInteger encrypt( String hexStr, BigInteger publicKey){ BigInteger str = new BigInteger( hexStr, 16 ); BigInteger c = str.modPow( publicKey, this.modulus ); return c; } //decrypt public char decrypt( BigInteger c , BigInteger D, BigInteger N ){ BigInteger m = c.modPow( D,N ); return (char)Integer.parseInt(m.toString(16),16); } private int keyBitLen = 512; private SecureRandom sRand = new SecureRandom(); private BigInteger NEGONE = new BigInteger( "-1" ); protected BigInteger publicKey, privateKey, modulus = new BigInteger( "-1" ); public int getKeyLength(){ return keyBitLen; } public BigInteger getN(){ return modulus; } public BigInteger getE(){ return publicKey; } public BigInteger getD(){ return privateKey; } //generate key public void generateRSAKeys( int bitLength ){ BigInteger p = BigInteger.probablePrime( ( bitLength/16), this.sRand ); BigInteger q = BigInteger.probablePrime( ( bitLength/16), this.sRand );
65 BigInteger n = p.multiply( q ); BigInteger phi = ( p.subtract( BigInteger.ONE ) ). multiply( q.subtract( BigInteger.ONE ) ); BigInteger publicKey=BigInteger.probablePrime( (bitLength/256), this.sRand ); BigInteger privateKey = publicKey.modInverse(phi); while( publicKey.gcd( phi ).compareTo( BigInteger.ONE ) != 0 ){ publicKey = publicKey.add( BigInteger.ONE ); if( publicKey.compareTo( phi ) == 1 ){ // Unable to find keys, try again this.generateRSAKeys( bitLength ); } } this.publicKey = publicKey; this.privateKey = privateKey; this.modulus = n; // Generates usable RSA keys based on message size. // Results can be accessed from invoking RSA.genPublicKey, // RSA.genPrivateKey, and RSA.genModulus public void generateRSAKeys( String message ){ BigInteger temp = new BigInteger( message, 16 ); this.generateRSAKeys( temp.bitLength() * 2 ); } // Allows user to get the private key protected BigInteger getPrivateKey(){ return this.privateKey; } // Allows user to get the public key protected BigInteger getPublicKey(){ return this.publicKey; } // Allows user to get the modulus protected BigInteger getModulus(){ return this.modulus; } }
Dalam class RSA() mempunyai dua tugas penting yaitu melakukan proses pembuatan kunci dengan sintak. public void BigInteger this.sRand BigInteger this.sRand
generateRSAKeys( int bitLength ){ p = BigInteger.probablePrime( ( bitLength/2), ); q = BigInteger.probablePrime( ( bitLength/2), );
66 BigInteger n = p.multiply( q ); BigInteger phi = ( p.subtract( BigInteger.ONE ) ). multiply( q.subtract( BigInteger.ONE ) ); BigInteger publicKey = new BigInteger( "2" ); BigInteger privateKey = publicKey.modInverse(phi); while( publicKey.gcd( phi ).compareTo( BigInteger.ONE ) != 0 ){ publicKey = publicKey.add( BigInteger.ONE ); if( publicKey.compareTo( phi ) == 1 ){ this.generateRSAKeys( bitLength ); } } this.publicKey = publicKey; this.privateKey = privateKey; this.modulus = n; public void generateRSAKeys( String message ){ BigInteger temp = new BigInteger( message, 16 ); this.generateRSAKeys( temp.bitLength() * 2 ); } protected BigInteger getPrivateKey(){ return this.privateKey; } protected BigInteger getPublicKey(){ return this.publicKey; } protected BigInteger getModulus(){ return this.modulus; }
Perlu diingat bahwa dalam menggunakan metode RSA sesuai algoritma pembentuk kunci publik dan kunci privat, proses penentuan p dan q haruslah bilangan prima, penulis menggunakan angka acak (random) yang digunakan untuk memudahkan pengguna agar tidak perlu menginput p dan q secara manual, tetapi secara otomatis. Tugas kedua adalah melakukan proses enkripsi dan dekripsi dengan sintak : //encrypt public BigInteger encrypt( String hexStr, BigInteger publicKey){ BigInteger str = new BigInteger( hexStr, 16 ); BigInteger c = str.modPow( publicKey, this.modulus );
67 return c; } //decrypt public char decrypt( BigInteger c , BigInteger D, BigInteger N ){ BigInteger m = c.modPow( D,N ); return (char)Integer.parseInt(m.toString(16),16); }
Proses enkripsi dilakukan dengan fungsi parameter, dan parameter yang digunakan adalah parameter BigInteger hexStr dan parameter BigInteger publicKey. BigInteger hexStr merupakan parameter isi pesan yang akan dikirim ke nomor tujuan yang telah dimasukkan, jadi untuk mengirimkan pesan yang bertipe text, mula-mula text harus diubah tipe datanya menjadi BigInterger dalam proses enkripsi agar memudahkan dalam proses perhitungan dan BigInteger dikembalikan lagi ke text untuk proses dekripsi. Dalam aplikasi Pengaman SMS ini penulis menggunakan standard kode ASCII untuk mengubah setiap karakter menjadi bentuk biner sehingga pengguna dan penerima hanya tinggal menggunakan aplikasi Pengaman SMS ini. Sintak yang sangat penting dalam proses enkripsi dan dekripsi pada aplikasi Pengaman SMS ini adalah sebagai berikut. //encrypt BigInteger c = str.modPow( publicKey, this.modulus ); //decrypt BigInteger m = c.modPow( D,N );
Penggunaan modPow merupakan operasi matematika yang sangat berperan penting untuk pemangkatan yang besar dalam metode kriptografi RSA. 5.1.3
Pembahasan Tampilan Layout Inbox Tampilan ini mempunyai fungsi menampilkan list pesan yang ada di bawaan inbox Android yang nantinya akan digunakan untuk melakukan proses dekripsi pesan. Tampilan dari pilihan Inbox pada Gambar 5.5 berikut.
68
Gambar 5.5 Tampilan Inbox Dalam menampilkan list pesan, pengguna sebelumnya memilih tombol Baca Pesan secara otomatis akan muncul kotak dialog List SMS yang masuk. Pada list SMS hanya menampilkan nomor telepon pengirim dan SMS yang dikirim dan untuk kuncinya dikirim berbeda. List SMS ini secara otomatis update setiap kali ada SMS masuk, baik SMS biasa ataupun SMS yang telah terenkripsi. Proses alur dalam bentuk flowchart ditampilkan oleh Gambar 5.6 berikut.
Gambar 5.6 Flowchart Proses Inbox
69 Dalam tampilan Inbox ini, class yang termasuk dalam proses tampilan ini adalah class inboxsms() yang nantinya akan berhubungan dengan class baca(). Pembuatan koding dari class inboxsms() adalah sebagai berikut: public class inboxsms extends ListActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); List<SMSData> smsList = new ArrayList<SMSData>(); Uri uri = Uri.parse("content://sms/inbox"); Cursor c= getContentResolver().query(uri, null, null , null,null); startManagingCursor(c); String datasms[]; datasms=new String[c.getCount()]; // Read the sms data and store it in the list if(c.moveToFirst()) { for(int i=0; i < c.getCount(); i++) { SMSData sms = new SMSData(); sms.setBody(c.getString(c.getColumnIndexOrThrow ("body")).toString()); sms.setNumber(c.getString(c.getColumnIndexOrThrow ("address")).toString()); smsList.add(sms); datasms[i]=sms.getNumber()+"\n"+sms.getBody(); c.moveToNext(); } } ArrayAdapter<String> adapter = new ArrayAdapter<String> (this, android.R.layout.simple_list_item_1, datasms); setListAdapter(adapter); } protected void onListItemClick(ListView l, View v, int position, long id) { String sms = (String)getListAdapter().getItem(position); String data[]=sms.split("\n"); String isi[]=data[1].split("\\.",2); String kunci[]=isi[0].split("\\-",2); Intent i=new Intent(this,baca.class); //oper nomor pengirim ke form baca //oper isi pengirim ke form baca i.putExtra("no", data[0]); //oper isi pengirim ke form baca
70 i.putExtra("sms", isi[1]); //memecah kunci d i.putExtra("key1", kunci[0]); //memecah kunci N i.putExtra("key2", kunci[1]); startActivity(i);
} }
Dalam proses class dari class inboxsms() terdapat satu function dan dua macam proses . Function yang terdapat pada class ini berfungsi untuk memanggil pesan yang berada pada inbox bawaan dari Android dapat ditampilkan di list pesan pada aplikasi Pengaman SMS ini. Function untuk pemanggilan inbox bawaan Android ini dipanggil dengan sintak dibawah ini. Uri uri = Uri.parse("content://sms/inbox");
Setelah function terdapat dua buah proses yaitu yang pertama adalah proses yang berfungsi untuk menampilkan list pesan di tampilan Inbox dan proses kedua adalah proses untuk memanggil class baca() dan memindahkan data pesan dari list pesan dapat tertampil di class baca(). Pembuatan koding proses menampilkan list pesan adalah sebagai berikut : protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); List<SMSData> smsList = new ArrayList<SMSData>(); Uri uri = Uri.parse("content://sms/inbox"); Cursor c= getContentResolver().query(uri, null, null , null,null); startManagingCursor(c); String datasms[]; datasms=new String[c.getCount()]; // Read the sms data and store it in the list if(c.moveToFirst()) { for(int i=0; i < c.getCount(); i++) { SMSData sms = new SMSData(); sms.setBody(c.getString(c.getColumnIndexOrThrow ("body")).toString()); sms.setNumber(c.getString(c.getColumnIndexOrThrow ("address")).toString()); smsList.add(sms);
71 datasms[i]=sms.getNumber()+"\n"+sms.getBody(); c.moveToNext(); } } ArrayAdapter<String> adapter = new ArrayAdapter<String> (this, android.R.layout.simple_list_item_1, datasms); setListAdapter(adapter); }
Dalam proses ini bisa disebut sebagai main class dari class inboxsms() dan untuk menampilkan sms yang ter-update maka aplikasi ini memanggil function yang ada pada class ini, seperti yang sudah dijelaskan sebelumnya, list dalam proses pemanggilan pesan ini bersifat array, dan aplikasi ini menggunakan array yang berasal bawaan dari Android. Proses yang kedua adalah membuat class inboxsms() dapat terhubung dengan class baca() yang berguna untuk melakukan proses menterjemahkan pesan yang disandikan. Berikut koding proses pemanggilan class baca() dari class inboxsms(). protected void onListItemClick(ListView l, View v, int position, long id) { String sms = (String)getListAdapter().getItem(position); String data[]=sms.split("\n"); String isi[]=data[1].split("\\.",2); String kunci[]=isi[0].split("\\-",2); Intent i=new Intent(this,baca.class); //oper nomor pengirim dan isi ke form baca i.putExtra("no", data[0]); i.putExtra("sms", isi[1]); //memecah kunci d dan kunci N i.putExtra("key1", kunci[0]); i.putExtra("key2", kunci[1]); startActivity(i);
} }
Bisa dilihat bahwa proses ini berjalan saat pengguna klik pesan yang ingin dibaca pada list sms dan otomatis pesan dan no telepon pengirim akan ditampilkan di tampilan Baca Pesan. Sintak Intent dan start activity merupakan sintak yang digunakan untuk memanggil class lain.
72 5.1.4
Pembahasan Tampilan Layout Baca Pesan Dalam tampilan ini, proses ini hanya akan berjalan jika pengguna memilih pilihan “Baca Pesan” pada tampilan awal dan klik list pesan yang ingin dibaca. Class yang digunakan dalam tampilan ini adalah class baca(). Pada tampilan baca pesan ini nomor pengirim, isi pesan, kunci d dan kunci N akan secara otomatis terisi ketika penerima memilih pesan yang berada pada list SMS pada tampilan inbox. Kunci d dan kunci N berfungsi untuk melakukan proses dekripsi pesan. Untuk Berikut tampilan baca pesan seperti Gambar 5.7.
Gambar 5.7 Tampilan Baca Pesan Berikut alur flowchart dalam proses dari tampilan baca pesan pada Gambar 5.8.
73
Gambar 5.8 Flowchart Proses Tampilan Baca Pesan Berikut proses pembuatan koding dari tampilan baca pesan ini dengan class baca(). public class baca extends Activity { StringBuilder original=new StringBuilder(); String pesan , plain , kunci_dd , kunci_nn, no, isi, kunci1,kunci2, arrayisi[]=new String[2]; EditText pho_no , isi_pesan , kunci_d , kunci_n ; TextView pesan_terjemah ; Button terjemah; public void onCreate(Bundle savedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.baca); Bundle extras=getIntent().getExtras(); pho_no = (EditText)findViewById(R.id.phone_no_pengirim); isi_pesan = (EditText)findViewById(R.id.isi_pesan_enkrip); kunci_d = (EditText)findViewById(R.id.kunci_d); kunci_n = (EditText)findViewById(R.id.kunci_N); pesan_terjemah = (TextView)findViewById (R.id.plaintext_pesan); no=extras.getString("no"); isi=extras.getString("sms"); kunci1=extras.getString("key1");
74 kunci2=extras.getString("key2"); pho_no.setText(no); isi_pesan.setText(isi); kunci_d.setText(kunci1); kunci_n.setText(kunci2); terjemah = (Button)findViewById(R.id.dekrip); terjemah.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { long startTime = System.currentTimeMillis(); original=new StringBuilder(); pesan = isi_pesan.getText().toString().trim(); kunci_dd = kunci_d.getText().toString(); kunci_nn = kunci_n.getText().toString(); RSA test_akhir = new RSA(); String code[]=pesan.split("[.]"); if (kunci_dd.length()>0 && kunci_nn.length()>0){ BigInteger d_key = new BigInteger(kunci_dd); BigInteger n_key = new BigInteger(kunci_nn); for(int i=0;i
0){ Toast.makeText(getBaseContext(),"Kunci d harus diisi", Toast.LENGTH_LONG).show(); } else if (kunci_dd.length()>0 && kunci_nn.length()==0){ Toast.makeText(getBaseContext(),"Modulus harus diisi", Toast.LENGTH_LONG).show(); } long endTime = System.currentTimeMillis(); System.out.println("It took " + (endTime - startTime) + " milliseconds"); } }); } }
75 Dalam pembuatan koding ini, yang pertama kali harus dilakukan adalah melakukan pemindahan data pesan yang ada di class inboxsms() ke class baca() dengan memanggil sintak. setContentView(R.layout.baca); //sintak ini berfungsi untuk memanggil data yang ada pada class inboxsms() Bundle extras=getIntent().getExtras(); no=extras.getString("no"); isi=extras.getString("sms"); kunci1=extras.getString("key1"); kunci2=extras.getString("key2"); pho_no.setText(no); isi_pesan.setText(isi); kunci_d.setText(kunci1); kunci_n.setText(kunci2);
Sebelum proses dekripsi dilakukan langkah awal yaitu mengubah tipe data pada kunci dan pesan yang awalnya adalah bertipe string diubah ke tipe data BigInteger dengan sintak. BigInteger d_key = new BigInteger(kunci_dd); BigInteger n_key = new BigInteger(kunci_nn); for(int i=0;i
Dan barulah memanggil class RSA() dan melakukan proses dekripsi dengan sintak. RSA test_akhir = new RSA(); String code[]=pesan.split("[.]"); if (kunci_dd.length()>0 && kunci_nn.length()>0){ BigInteger d_key = new BigInteger(kunci_dd); BigInteger n_key = new BigInteger(kunci_nn); for(int i=0;i
5.2 Proses Uji Coba Aplikasi Pengaman SMS Pada uji coba kali ini akan dilakukan percobaan terhadap masing-masing interface yang terkait dengan peranan fungsi enkripsi dan dekripsi, pengiriman dan penerimaan pesan.
76 Contoh: Berikut Tahap uji coba dari aplikasi Pengaman SMS ini: 1. Pengguna 1 (5554) membuka aplikasi Pengaman SMS seperti Gambar 5.9 dan pilih menu Tulis Pesan.
Gambar 5.9 Membuka aplikasi Pengaman SMS 2. Ketik nomor tujuan pengguna 2 dan isi pesan (“pin 34$2!7*”) dan klik tombol kirim pesan untuk melakukan proses enkripsi pesan dan pengiriman pesan seperti pada Gambar 5.11.
Gambar 5.10 Proses Pengiriman SMS
77 Kunci D Kunci N Ciphertext
= 9653194557051039019 = 14479791843188146243 = 1404928.1157625.1331000.32768. 132651.140608.466656.125000. 35937.166375.74088. 3. Pengguna 2 (5556) akan menerima pesan dari pengguna 1 dalam 2 sisi yaitu seperti Gambar 5.11 dan Gambar 5.12 :
Gambar 5.11 Tampilan Inbox Bawaan Android
Gambar 5.12 Tampilan Inbox pada Pengaman SMS
78 4. Pengguna dua klik pesan yang ingin didekripsikan dan pengguna dua harus mengisi kunci D dan N yang sudah dikirimkan oleh pengguna 1
Gambar 5.13 Proses Dekripsi Benar Jika kunci yang dimasukkan benar maka pesan asli dapat muncul seperti pada Gambar 5.13. Jika salah satu kunci atau kedua kunci yang dimasukkan salah, maka pesan tidak terbaca seperti pada Gambar 5.14 berikut.
Gambar 5.14 Proses Dekripsi Salah
79 5.3 Uji Coba Validitas Pesan Saat Enkripsi dan Dekripsi Uji coba ini bertujuan untuk memperlihatkan validitas SMS yang akan dikirim sesuai atau tidak dengan SMS yang akan diterima. Pada Tabel 5.1 berikut ini akan ditampilkan beberapa data percobaan yang memperlihatkan validitas pesan saat dilakukan proses enkripsi dan dekripsi (Data lebih lengkap dapat dilihat di Lampiran pada akhir tugas akhir ini). Tabel 5.1 Validitas pesan saat enkripsi dan dekripsi Percobaan ke
Plaintext
1
Halo apa kabar
2
Nama kamu siapa
3
Andi Riski Alvianto
Hasil Ciphertext (Enkripsi) 373248.912673. 1259712.1367631. 32768.912673. 1404928.912673. 32768.1225043. 912673.941192. 912673.1481544. 474552.912673. 1295029.912673. 32768.1225043. 912673.1295029. 1601613.32768. 1520875.1157625. 912673.1404928. 912673. 274625.1331000. 1000000.1157625. 32768.551368. 1157625.1520875. 1225043.1157625. 32768.274625. 1259712.1643032. 1157625.912673. 1331000.1560896. 1367631.
Plaintext (Dekripsi)
Halo apa kabar
Nama kamu siapa
Andi Riski Alvianto
80
4
Desa Kramat Nganjuk
5
1210100040
314432.1030301. 1520875.912673. 32768.421875. 1481544.912673. 1295029.912673. 1560896.32768. 474552.1092727. 912673.1331000. 1191016.1601613. 1225043. 117649.125000. 117649.110592. 117649. 110592. 110592. 110592. 140608. 110592.
Desa Kramat Nganjuk
1210100040
Dari presentasi keseluruhan uji coba diperoleh rata-rata kesesuaian plaintext pada saat sebelum dienkripsi dan sesudah didekripsi pada seluruh data hasil uji coba adalah 100%. Jadi dapat disimpulkan bahwa validitas pesan saat sebelum proses enkripsi dan setelah dilakukan proses dekripsi adalah sesuai, sehingga keamanan plaintext dapat terjamin kerahasiaannya. 5.4 Uji Coba Response Time pada Enkripsi dan Dekripsi Pada uji coba kali ini akan dilakukan pengukuran response time yang diperlukan pada saat proses enkripsi dan dekripsi dijalankan. Pengukuran waktu dibandingkan dengan jumlah karakter pesan yang dibuat, dengan satuan waktu dalam detik. Uji coba dilaksanakan sebanyak 30 kali dengan hasil yang terlihat pada Gambar 5.15. Data-data percobaan yang dilakukan dilampirkan pada bagian akhir tugas akhir ini.
81
Gambar 5.15 Grafik Response Time enkripsi berdasarkan jumlah karakter pesan Dari percobaan tersebut diperoleh response time rata-rata proses enkripsi adalah 0,014925 detik per karakter atau 14,925 milidetik per karakter. Demikian juga halnya dengan proses dekripsi dilakukan hal yang sama, sehingga diperoleh grafik seperti Gambar 5.16 berikut ini.
Gambar 5.16 Grafik Response Time dekripsi berdasarkan jumlah karakter pesan Dari percobaan tersebut diperoleh response time rata-rata proses dekripsi adalah 0,004679 detik per karakter atau 4,679 milidetik per karakter.
82
”Halaman ini sengaja dikosongkan”
BAB VI PENUTUP 6.1 Simpulan Berdasarkan hasil dari pembuatan dan uji coba yang dilakukan terhadap aplikasi SMS kriptografi dengan menerapkan metode RSA pada android, maka didapatkan simpulan seperti : 1. Validitas pesan yang akan dikirim setelah melakukan proses enkripsi dan dekripsi adalah 100% sehingga untuk keamanan pengiriman pesan asli terjamin aman. 2. Membuktikan bahwa metode RSA tidak hanya cuma digunakan untuk mengamankan data dan digital signature, tetapi metode ini dapat diterapkan untuk proses pengiriman dan penerimaan pesan berbasis SMS. 3. Penyamaran pesan menjadi ciphertext pada saat proses enkripsi dengan Algoritma RSA dapat mencegah orang lain untuk mengetahui pesan asli yang dimaksud. 4. Response time rata-rata untuk proses enkripsi yaitu 14,925 milidetik per karakter, sedangakan untuk proses dekripsi ratarata response time-nya adalah 4,679 milidetik per karakter. 6.2 Saran Dengan melihat hasil yang dicapai pada penelitian ini, ada beberapa hal yang penulis sarankan untuk pengembangan selanjutnya, yaitu : 1. Aplikasi ini dapat dikembangkan tidak sebatas hanya untuk SMS saja tetapi media sosial lainnya yang bersangkutan dengan pengiriman pesan seperti Line, Whatsapp, BBM, dan lain-lain. 2. Parameter titik pada ciphertext dihilangkan, jika bisa tidak hanya angka saja tetapi ditambah dengan kombinasi huruf. 3. Untuk pengiriman SMS bisa lebih dari satu penerima atau multiuser.
83
DAFTAR PUSTAKA
[1]
[2]
[3]
[4]
[5]
[6]
[7]
[8] [9]
Enterprise, J. (2013). “Memahami Pemrograman Android secara cepat dan mudah”. Cetakan Pertama. Elex Media Komputindo. Jakarta. Heriyanto, T., dan Arradian, D. (2014). “Perkembangan Android Bagi Pendidikan”. http://rastafarareggaeman.blogspot.com. (diakses pada tanggal 25 November 2014) Nosrati, M. (2012). “Mobile Computing : Principles, Devices, and Operating Systems”. World Applied Programming Journal. Noor, A. R. (2008). “Tarif SMS di Indonesia, Mahal atau Murah”. http://inet.detik.com/read/2008/01/16/094747/879587/328/t arif-sms-di-indonesia-mahal-atau-murah. (diakses pada tanggal 7 November 2014) Kastawan, I K. (2003). “Pembuatan Perangkat Lunak Pengaman Pengiriman Pesan Via Email dengan Algoritma RSA”. Tugas Akhir Jurusan Matematika Institut Teknologi Sepuluh Nopember. Surabaya. Sunarsa, R. (2012). “Membedakan Encoding dan Encryption”. http://blog.randisunarsa.web.id/?p=271 (diakses pada tanggal 28 November 2014) Ariyus, D. (2008). “Pengantar Ilmu Kriptografi – Teori Analisis dan Implementasi”. Edisi Pertama. Penerbit ANDI. Yogyakarta. Sadikin, R. (2012). “Kriptografi untuk Keamanan Jaringan”. Edisi Pertama. Penerbit ANDI. Yogyakarta. Ariyus, D. (2006). “Kriptografi – Keamanan Data dan Komunikasi”. Cetakan Pertama. GRAHA ILMU. Yogyakarta.
85
86 [10] Elgin, B. (2005). “Google Buys Android for Its Mobile Arsenal”. Bloomberg Businessweek. Bloomberg. Diarsipkan dari aslinya tanggal 24 Februari 2011. [11] Welch, C. (2013). “Before it took over smartphones, Android was originally destined for cameras”. The Verge. Diakses tanggal 1 Mei 2013. [12] Romsy. (2011). “Sistem Operasi pada Handphone”.
http://romsyuchiha.wordpress.com/2011/05/18/sistemoperasi-pada-handphone/. (diakses pada tanggal 2 Desember 2014) [13] Sirohito, A. (2012). “Memaksimalkan Kemampuan Android”. http://sirohito.wordpress.com/2012/07/28/memaksima lkan-kemampuan-android/. (diaksses pada tanggal 30 November 2014) [14] Nadia. (2013). “Pengertian SMS (Short Message Service)”. Rapendik. http://rapendik.com/program/pengayaanpembelajaran/petik /561-pengertian-sms-short-message-service. (diakses pada tanggal 11 Februari 2014) [15] Faritzah. (2013). “Layanan Pesan Singkat”. http://modernpyramid.wordpress.com/2013/01/18/layananpesan-singkat. (diakses pada tanggal 1 Desember 2014) [16] Safaat, N. (2013). “Berbagai Implementasi dan Pengembangan Aplikasi Mobile Berbasis Android”. Cetakan Pertama. INFORMATIKA. Bandung. [17] Alfatta, H. (2007). “Analisis dan Perancangan Sistem Informasi”. Edisi Pertama. Penerbit ANDI. Yogyakarta.
84
”Halaman ini sengaja dikosongkan”
LAMPIRAN A. Cara Menginstal Perangkat Lunak
Untuk dapat menjalankan perangkat lunak ini dengan baik, maka diperlukan setup beberapa hal sebagai berikut. 1. Download atau copy PengamanSMS.apk 2. Klik icon PengamanSMS.apk untuk memulai instalasi. 3. Sebelum diinstall PengamanSMS.apk meminta persetujuan. 4. Setelah instalasi selesai PengamanSMS siap dijalankan.
B. Syarat Pendukung Perangkat Lunak
Perangkat lunak ini telah dicoba dan berjalan dengan baik pada piranti-piranti sebagai berikut. 1. Laptop Acer Aspire 4741 2. Processor Intel® CoreTM i5 CPU M 450 @ 2.40GHz 3. Memory 2.00 GB 4. Microsoft Windows 8.1 Pro 5. Eclipse IDE
C. Data-Data Uji Coba
C.1 Percobaan untuk Response Time Proses Enkripsi Waktu Percobaan Karakter Waktu Enkripsi Enkripsi per ke Karakter 1 5 0.784 0.1568 2 10 0.406 0.0406 3 15 0.375 0.025 4 20 0.448 0.0224 5 25 0.642 0.02568 6 30 0.31 0.010333333 7 35 0.463 0.013228571 8 40 0.583 0.014575 9 45 0.553 0.012288889 87
88 10 50 11 55 12 60 13 65 14 70 15 75 16 80 17 85 18 90 19 95 20 100 21 105 22 110 23 115 24 120 25 125 26 130 27 135 28 140 29 145 30 150 Rata-rata
0.394 0.499 0.452 0.512 0.402 0.464 0.459 0.535 0.455 0.536 0.499 0.553 0.614 0.534 0.883 0.627 0.542 0.712 0.587 0.722 1.252 0.5599
0.00788 0.009072727 0.007533333 0.007876923 0.005742857 0.006186667 0.0057375 0.006294118 0.005055556 0.005642105 0.00499 0.005266667 0.005581818 0.004643478 0.007358333 0.005016 0.004169231 0.005274074 0.004192857 0.00497931 0.008346667 0.014924867
C.2 Percobaan untuk Response Time Proses Dekripsi Percobaan Waktu Dekripsi Karakter Waktu Dekripsi ke per Karakter 1 7 0.31 0.044285714 2 16 0.466 0.029125 3 23 0.207 0.009
89 4 30 5 37 6 44 7 50 8 57 9 64 10 71 11 79 12 87 13 94 14 101 15 108 16 115 17 122 18 130 19 137 20 144 21 150 22 156 23 163 24 170 25 177 26 183 27 190 28 197 29 204 30 211 Rata-rata
0.177 0.192 0.135 0.137 0.155 0.178 0.123 0.147 0.19 0.142 0.314 0.14 0.252 0.21 0.266 0.385 0.19 0.289 0.375 0.194 0.213 0.231 0.222 0.225 0.232 0.228 0.214 0.224633333
0.0059 0.005189189 0.003068182 0.00274 0.002719298 0.00278125 0.001732394 0.001860759 0.002183908 0.001510638 0.003108911 0.001296296 0.002191304 0.001721311 0.002046154 0.002810219 0.001319444 0.001926667 0.002403846 0.001190184 0.001252941 0.001305085 0.001213115 0.001184211 0.001177665 0.001117647 0.001014218 0.004679185
C.3 Validitas Pesan Saat Enkripsi dan Dekripsi Hasil Percobad modulus plaintext ciphertext (enkripsi) an ke 11231 16847 373248.912673. 1259712.1367631. 99131 98697 Halo apa 32768.912673.1404928.912673. 1 13811 52839 kabar 32768.1225043.912673.941192. 59659 29693 912673.1481544. 99439 14915 474552.912673.1295029.912673. 04605 85691 Nama kamu 32768.1225043.912673.1295092. 2 51434 60321 siapa 1601613.32768.1520875.1157625. 5379 33753 912673.1404928.912673. 274625.1331000.1000000.1157625. 10507 15761 32768.551368.1157625.1520875. 86206 79309 Andi Riski 3 1225043.1157625.32768.274625. 08360 91957 Alvianto 1259712.1643032.1157625.912673. 38123 36741 1331000.1560896.1367631. 10154 15231 421875.1481544.912673.1295029. 06809 10215 Kramat 912673.1560896.32768.474552. 4 51055 04952 Nganjuk 1092727.912673.1331000.1191016. 60411 56387 1601613.1225043. 5 88501 13275 1210100040 117649.125000.117649.110592.
plaintext (dekripsi) Halo apa kabar Nama kamu siapa
Andi Riski Alvianto
Kramat Nganjuk 1210100040
6
7
8
9
10
06781 57298 4571 86136 18580 54580 6123 87482 53315 97179 0091 10279 01132 71776 04115 95166 08168 23819 4499 99468 33536 97894
16017 96534 29107 12920 42787 80466 21091 13122 37998 12415 98499 15418 51699 86197 47501 14274 91225 99282 84273 14920 25031 32258
117649.110592.110592.110592. 110592.140608.10592.
28041991
125000.175616.110592.140608. 117649.185193.185193.117649.
28041991
1234567890
117649.125000.132651.140608. 148877.157464.166375.175616. 185193.110592.
1234567890
2347621387
125000.132651.140608.166375. 157464.125000.117649.132651. 175616.166375.
2347621387
~!@#$%^&
2000376.35937.262144.42875. 46656.50653.830584.54872.
~!@#$%^&
*()_+=-{}|
74088.64000.68921.857375. 79507.2626981.91125.1860867. 1953125.1906624.
*()_+=-{}|
11
12
13
14
15
5195 78753 68518 39094 2011 91886 33349 07483 3963
20921 11813 05278 44606 83159 13782 95003 10924 05971
87127 47203 20113 1691
13069 12081 20375 53149
10972 36210 12784 61803 78382 06547 64885 2259
16458 54316 00358 10109 11757 30982 83310 73117
\][;'":
778688.804357.753571.205379. 59319.39304.195112.
\][;'":
?><,./;-)
250047.238328.216000.85184. 97336.103823.205379.91125. 68921.
?><,./;-)
nomorku 08565597693
Rumahku nomor 13 kode pos 64419
1331000.1367631.1295029.1367631. 1481544.1225043.1601613.32768. 110592.175616.148877.157464. 148877.148877.185193.166375. 157464.185193.132651.110592 551368.1601613.1295029.912673. 1124864.1225043.1601613.32768. 1331000.1367631.1295029.1367631. 1481544.32768.117649.132651. 1225043.1367631.1000000.1030301. 32768.1404928.1367631.1520875. 32768.157464.140608.140608. 117649.185193.
nomorku 08565597693
Rumahku nomor 13 kode pos 64419
16
17
18
19
20
74388 87545 10044 0219 93424 79936 47043 9163
11158 33132 43335 66003 14013 71991 22551 45319
92978 30513 07360 6923
13946 74577 71376 63929
97227 26747 03410 2859 90230 55319 45794 0635
14584 09012 82186 85103 13534 58298 65734 59091
pin bbm 7d107595
hasil 2^2+3=7
anrisk40 @gmail.com
1404928.1157625.1331000.32768. 941192.941192.1295029.32768. 166375.1000000.117649.110592. 166375.148877.185193.148877. 1124864.912673.1520875.1157625. 1259712.32768.125000.830584. 125000.79507.132651.226981. 166375. 912673.1331000.1481544.1157625. 1520875.1225043.140608.110592. 262144.1092727.1295029.912673. 1157625.1259712.97336.970299. 1367631.1295029.
pin bbm 7d107595
hasil 2^2+3=7
anrisk40 @gmail.com
pin 2&j9)o>
1404928.1157625.1331000.32768. 125000.54872.1191016.185193. 68921.1367631.238328.
pin 2&j9)o>
34% * 2 = 68%
132651.140608.50653.32768. 74088.32768.125000.32768. 226981.32768.157464.175616. 50653.
34% * 2 = 68%
94
”Halaman ini sengaja dikosongkan”
BIODATA PENULIS
Penulis memiliki nama lengkap Andi Riski Alvianto atau biasa dipanggil Andi. Penulis dilahirkan di Nganjuk pada 28 April 1991 dan merupakan anak pertama dari 2 bersaudara. Pendidikan formal yang pernah ditempuh yaitu di TK Nurul Huda Tambun Selatan, SDN Mekarsari 1 Tambun SelatanBekasi, MTsN Nganjuk, dan SMKN 1 Nganjuk. Setelah lulus dari SMK, penulis mendaftar program beasiswa Bidikmisi dan diterima di Jurusan Matematika FMIPA ITS pada tahun 2010 dan terdaftar dengan NRP. 1210 100 040. Di Jurusan Matematika FMIPA ITS, penulis mengambil bidang minat Ilmu Komputer. Penulis aktif di beberapa organisasi intra kampus diantaranya kepengurusan HIMATIKA sebagai staf Departemen Dalam Negeri periode 2011-2012 dan periode 20122013. Selain itu, penulis juga aktif dalam kepengurusan BEM FMIPA ITS sebagai staf Departemen Sosial Masyarakat periode 2011-2012 dan Kepala Biro Lingkungan Departemen Sosial Masyarakat periode 2012-2013. Penulis juga mengikuti Lembaga Dakwah Jurusan sebagai staf kaderisasi Ibnu Muqlah periode 2012-2013. Selain intra kampus, penulis juga mengikuti organisasi ekstra kampus sebagai staf UKM Olah Raga Air ITS Divisi Renang. Penulis juga aktif dalam berbagai kegiatan pelatihan kemahasiswaan, diantaranya LKMM Pra TD FMIPA 2010, LKMM TD HIMATIKA 2011. Disamping itu pada semester 7 penulis menjadi asisten dosen matakuliah Microsoft SQL Server 2005 di PAPSI. Untuk kritik, saran, informasi dan pertanyaan yang berhubungan mengenai Tugas Akhir ini dapat dikirimkan melalui e-mail ke [email protected].