Algoritma Blowfish adalah salah satu algoritma yang dapat digunakan untuk melakukan enkripsi data sehingga data asli hanya dapat dibaca oleh seseorang yang memiliki kunci enkripsi tersebut. Contoh yang dibahas kali ini adalah mengenai enkripsi dan dekripsi dari sebuah kalimat.
Algoritma ini menggunakan teknik cipher blok dengan key simetris. Blowfish memiliki ukuran blok 64 bit dan panjang key dari 32 sampai 448 bit. Blowfish menggunakan cipher Feistel dan menggunakan parameter SBOX yang sangat besar dan nilainya bergantung dari key. Strukturnya sangat mirip dengan struktur CAST-128, yang menggunakan SBOX dengan nilai tetap.
Langkah-langkah penggunaan algoritma ini adalah
1. Tentukan kalimat yang akan dienkrip
Console.WriteLine("Masukkan kalimat yang akan dienkrip: ") Dim input As String = Console.ReadLine
2. Tentukan kata kunci enkripsi yang digunakan
Console.WriteLine("Masukkan kata kunci enkripsi: ") Dim kataKunci As String = Console.ReadLine
3. Lakukan inisialisasi variabel yang digunakan oleh metode ini
Penjelasan lebih detail tentang fungsi ini dapat dilihat pada penjelasan skrip dibawah ini
Dim xc As New CryptCore() xc.InitCore() xc.Key = kataKunci
* Skrip tersebut akan melakukan inisialisasi pada Class CryptCore. Class ini adalah inti class untuk pemanggilan fungsi enkripsi dan dekripsi yang mengacu pada algoritma blowfish. Deklarasi Class CryptCore adalah sebagai berikut:
Public Class CryptCore Private _key As String = Nothing Public Property Key() As String Get Return _key End Get Set(value As String) _key = Me.formatKey(value) End Set End Property Private Function formatKey(key As String) As String If key Is Nothing OrElse key.Length = 0 Then Return Nothing End If Return key.Trim() End Function Private DefaultKey As String = "" Public Sub New() DefaultKey = "enkripsi" End Sub Private _coreSymmetric As CoreAlgoritmaSymmetric Public Function InitCore() As Boolean _coreSymmetric = New CoreAlgoritmaSymmetric() Return True End Function . . . End Class
* Pada saat melakukan proses InitCore, maka proses tersebut akan melakukan inisialisasi pada Class CoreAlgoritmaSymmetric. Pemanggilan fungsi enkripsi / dekripsi pada Class sebelumnya akan mengarah pada Class ini untuk selanjutnya dilakukan perhitungan enkripsi / dekripsi yang sebenarnya. Deklarasi Class CoreAlgoritmaSymmetric adalah sebagai berikut:
Public Class CoreAlgoritmaSymmetric Private metodeEncode As System.Security.Cryptography.SymmetricAlgorithm Public Sub New() metodeEncode = New BlowfishAlgoritma() metodeEncode.Mode = System.Security.Cryptography.CipherMode.CBC metodeEncode.KeySize = 40 metodeEncode.GenerateKey() metodeEncode.GenerateIV() End Sub . . . End Class
* Pada saat menginisialisasi variabel metodeEncode, maka proses tersebut akan melakukan inisialisasi pada Class BlowfishAlgoritma. Class ini berisi tentang beberapa properti dan fungsi yang menggantikan properti dan fungsi yang diturunkan dari Class SymmetricAlgorithm dan ICryptoTransform. Deklarasi Class BlowfishAlgoritma adalah sebagai berikut:
Public Class BlowfishAlgoritma Inherits System.Security.Cryptography.SymmetricAlgorithm Implements System.Security.Cryptography.ICryptoTransform Private m_bf As Blowfish Private m_bfcbc As BlowfishBaseCBC Private m_blIsEncryptor As Boolean Private m_rng As System.Security.Cryptography.RNGCryptoServiceProvider Public Sub New() MyBase.New() m_bf = Nothing m_bfcbc = Nothing IVValue = Nothing KeyValue = Nothing KeySizeValue = Blowfish.MaksPanjangKey * 8 LegalBlockSizesValue = New System.Security.Cryptography.KeySizes(0) {} LegalBlockSizesValue(0) = New System.Security.Cryptography.KeySizes(BlockSize, BlockSize, 8) LegalKeySizesValue = New System.Security.Cryptography.KeySizes(0) {} LegalKeySizesValue(0) = New System.Security.Cryptography.KeySizes(0, Blowfish.MaksPanjangKey * 8, 8) ModeValue = System.Security.Cryptography.CipherMode.ECB m_rng = Nothing End Sub . . . End Class
4. Lakukan enkripsi kalimat awal menggunakan algoritma ini
Penjelasan lebih detail tentang fungsi ini dapat dilihat pada penjelasan skrip dibawah ini
Dim hasilEnkripsi As String = xc.Encrypt(input)
* Skrip tersebut akan menjalankan proses enkripsi yang terdapat dalam Class CoreAlgoritmaSymmetric.
Public Function ProsesEncrypt(Source As String, Key As String) As String If Source Is Nothing OrElse Key Is Nothing OrElse Source.Length = 0 OrElse Key.Length = 0 Then Return Nothing End If If metodeEncode Is Nothing Then Return Nothing End If Dim lPanjangStream As Long Dim jumlahBufferTerbaca As Integer Dim byteBuffer As Byte() = New Byte(2) {} Dim srcData As Byte() = System.Text.ASCIIEncoding.ASCII.GetBytes(Source) Dim encData As Byte() Dim streamInput As New System.IO.MemoryStream() streamInput.Write(srcData, 0, srcData.Length) streamInput.Position = 0 Dim streamOutput As New System.IO.MemoryStream() Dim streamEncrypt As System.Security.Cryptography.CryptoStream metodeEncode.Key = GetValidKey(Key) metodeEncode.IV = GetValidIV(Key, metodeEncode.IV.Length) streamEncrypt = New System.Security.Cryptography.CryptoStream(streamOutput, metodeEncode.CreateEncryptor(), System.Security.Cryptography.CryptoStreamMode.Write) lPanjangStream = streamInput.Length Dim totalBufferTerbaca As Integer = 0 While totalBufferTerbaca < lPanjangStream jumlahBufferTerbaca = streamInput.Read(byteBuffer, 0, byteBuffer.Length) streamEncrypt.Write(byteBuffer, 0, jumlahBufferTerbaca) totalBufferTerbaca += jumlahBufferTerbaca End While streamEncrypt.Close() encData = streamOutput.ToArray() 'Konversi menjadi base64 agar hasil dapat digunakan dalam xml Return Convert.ToBase64String(encData) End Function
* Sedangkan proses enkripsi utama algoritma Blowfish adalah sebagai berikut
Protected Sub BaseEncrypt(ByRef unHiRef As UInteger, ByRef unLoRef As UInteger) Dim unHi As UInteger = unHiRef Dim unLo As UInteger = unLoRef Dim sbox1 As UInteger() = m_sbox1 Dim sbox2 As UInteger() = m_sbox2 Dim sbox3 As UInteger() = m_sbox3 Dim sbox4 As UInteger() = m_sbox4 Dim pbox As UInteger() = m_pbox unHi = unHi Xor pbox(0) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(1) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(2) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(3) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(4) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(5) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(6) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(7) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(8) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(9) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(10) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(11) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(12) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(13) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(14) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(15) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(16) unLoRef = unHi unHiRef = unLo Xor pbox(17) End Sub
5. Lakukan dekripsi dari kalimat yang telah terenkripsi
Penjelasan lebih detail tentang fungsi ini dapat dilihat pada penjelasan skrip dibawah ini
Dim hasilDekripsi As String = xc.Decrypt(hasilEnkripsi)
* Skrip tersebut akan menjalankan proses dekripsi yang terdapat dalam Class CoreAlgoritmaSymmetric.
Public Function ProsesDecrypt(Source As String, Key As String) As String If Source Is Nothing OrElse Key Is Nothing OrElse Source.Length = 0 OrElse Key.Length = 0 Then Return Nothing End If If metodeEncode Is Nothing Then Return Nothing End If Dim lPanjangStream As Long Dim jumlahBufferTerbaca As Integer Dim byteBuffer As Byte() = New Byte(2) {} Dim encData As Byte() = Convert.FromBase64String(Source) Dim decData As Byte() Dim streamInput As New System.IO.MemoryStream(encData) Dim streamOutput As New System.IO.MemoryStream() Dim streamDecrypt As System.Security.Cryptography.CryptoStream metodeEncode.Key = GetValidKey(Key) metodeEncode.IV = GetValidIV(Key, metodeEncode.IV.Length) streamDecrypt = New System.Security.Cryptography.CryptoStream(streamInput, metodeEncode.CreateDecryptor(), System.Security.Cryptography.CryptoStreamMode.Read) lPanjangStream = streamInput.Length Dim totalBufferTerbaca As Integer = 0 While totalBufferTerbaca < lPanjangStream jumlahBufferTerbaca = streamDecrypt.Read(byteBuffer, 0, byteBuffer.Length) If 0 = jumlahBufferTerbaca Then Exit While End If streamOutput.Write(byteBuffer, 0, jumlahBufferTerbaca) totalBufferTerbaca += jumlahBufferTerbaca End While streamDecrypt.Close() decData = streamOutput.ToArray() For i As Integer = 0 To decData.Length - 1 If decData(i) < 8 Then decData(i) = 0 Next Dim encodeASCII As New System.Text.ASCIIEncoding() Return encodeASCII.GetString(decData) End Function
* Sedangkan proses dekripsi utama algoritma Blowfish adalah sebagai berikut
Public Overridable Sub Decrypt(ByRef unHiRef As UInteger, ByRef unLoRef As UInteger) Dim unHi As UInteger = unHiRef Dim unLo As UInteger = unLoRef Dim sbox1 As UInteger() = m_sbox1 Dim sbox2 As UInteger() = m_sbox2 Dim sbox3 As UInteger() = m_sbox3 Dim sbox4 As UInteger() = m_sbox4 Dim pbox As UInteger() = m_pbox unHi = unHi Xor pbox(CInt(17)) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(16) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(15) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(14) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(13) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(12) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(11) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(10) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(9) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(8) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(7) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(6) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(5) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(4) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(3) unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(2) unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(1) unLoRef = unHi unHiRef = unLo Xor pbox(0) End Sub
* Secara keseluruhan, skrip ini membutuhkan 2 Class tambahan yaitu Class Blowfish dan Class BlowfishBaseCBC. Class Blowfish berisi tentang ukuran blok, panjang key, semua nilai PBOX dan SBOX, dan beberapa fungsi enkripsi dan dekripsi dengan metode Blowfish. Class BlowfishBaseCBC adalah inti class Blowfish yang menggunakan teknik cipher CBC (Cipher Block Chaining), dan berisi tentang beberapa properti dan fungsi yang menggantikan properti dan fungsi yang diturunkan dari Class Blowfish dan SymmetricAlgorithm. Deklarasi kedua Class tersebut adalah sebagai berikut:
Public Class Blowfish 'Panjang maksimal ukuran key dalam byte Public Const MaksPanjangKey As Integer = 56 'Panjang ukuran blok dalam byte 'Perlu diingat bahwa ukuran data harus menyesuaikan ukuran blok Public Const ukuranBlok As Integer = 8 Const jumlahInputPBOX As Integer = 18 Const jumlahInputSBOX As Integer = 256 Private m_pbox As UInteger() Private m_sbox1 As UInteger() Private m_sbox2 As UInteger() Private m_sbox3 As UInteger() Private m_sbox4 As UInteger() . . . Public Sub New(key As Byte()) Dim nI As Integer m_pbox = New UInteger(jumlahInputPBOX - 1) {} For nI = 0 To jumlahInputPBOX - 1 m_pbox(nI) = InitPBOX(nI) Next m_sbox1 = New UInteger(jumlahInputSBOX - 1) {} m_sbox2 = New UInteger(jumlahInputSBOX - 1) {} m_sbox3 = New UInteger(jumlahInputSBOX - 1) {} m_sbox4 = New UInteger(jumlahInputSBOX - 1) {} For nI = 0 To jumlahInputSBOX - 1 m_sbox1(nI) = InitSBOX1(nI) m_sbox2(nI) = InitSBOX2(nI) m_sbox3(nI) = InitSBOX3(nI) m_sbox4(nI) = InitSBOX4(nI) Next 'Lakukan operasi XOR key pada semua pbox Dim panjangKey As Integer = key.Length If panjangKey = 0 Then Return Dim posisiKey As Integer = 0 Dim unBuild As UInteger = 0 For nI = 0 To jumlahInputPBOX - 1 For nJ As Integer = 0 To 3 unBuild = (unBuild << 8) Or key(posisiKey) If System.Threading.Interlocked.Increment(posisiKey) = panjangKey Then posisiKey = 0 End If Next m_pbox(nI) = m_pbox(nI) Xor unBuild Next 'Lakukan enkripsi pada semua box dengan semua string 0 Dim unZeroHi As UInteger = 0 Dim unZeroLo As UInteger = 0 For nI = 0 To jumlahInputPBOX - 1 Step 2 BaseEncrypt(unZeroHi, unZeroLo) m_pbox(nI) = unZeroHi m_pbox(nI + 1) = unZeroLo Next For nI = 0 To jumlahInputSBOX - 1 Step 2 BaseEncrypt(unZeroHi, unZeroLo) m_sbox1(nI) = unZeroHi m_sbox1(nI + 1) = unZeroLo Next For nI = 0 To jumlahInputSBOX - 1 Step 2 BaseEncrypt(unZeroHi, unZeroLo) m_sbox2(nI) = unZeroHi m_sbox2(nI + 1) = unZeroLo Next For nI = 0 To jumlahInputSBOX - 1 Step 2 BaseEncrypt(unZeroHi, unZeroLo) m_sbox3(nI) = unZeroHi m_sbox3(nI + 1) = unZeroLo Next For nI = 0 To jumlahInputSBOX - 1 Step 2 BaseEncrypt(unZeroHi, unZeroLo) m_sbox4(nI) = unZeroHi m_sbox4(nI + 1) = unZeroLo Next End Sub . . . End Class Public Class BlowfishBaseCBC Inherits Blowfish Private m_unIvHi As UInteger Private m_unIvLo As UInteger Public Sub New(key As Byte(), iv As Byte()) MyBase.New(key) Me.Iv = iv End Sub . . .
Hasil akhir adalah: (klik untuk perbesar gambar)
Contoh modul / source code dalam bahasa VB (Visual Basic) dapat didownload disini:
Jika membutuhkan jasa kami dalam pembuatan program, keterangan selanjutnya dapat dilihat di Fasilitas dan Harga
Jika ada yang kurang paham dengan langkah-langkah algoritma diatas, silahkan berikan komentar Anda.
Selamat mencoba.
Programnya koq error mas, mohon pencerahan
Skrip ini dapat berjalan baik sewaktu saya jalankan kembali. Silahkan disampaikan bagian manakah yang error dan pesan error apakah yang muncul.
apakah program dapat berjalan di vb versi terbaru?
Modul yang saya bagikan adalah modul bertipe “console application” sehingga seharusnya akan kompatibel jika dijalankan pada sebagian besar versi visual basic.
ketika programnya saya coba, ada bagian yang error gan. di bagian Public Class BlowfishAlgoritma gan.
Public Class BlowfishAlgoritma
Inherits System.Security.Cryptography.SymmetricAlgorithm
Implements System.Security.Cryptography.ICryptoTransform
blue underlined skrip yg 3 baris ini gan.? solusinya gimana ya gan.?
File yang saya bagikan adalah skrip bertipe konsol (kesalahan yang terjadi pada tempat anda mungkin disebabkan karena anda tidak menjalankan skrip dalam bentuk konsol). Setelah anda menjalankan Visual Studio, silahkan membuat proyek baru dengan tipe “Console Application”, kemudian salin isi skrip pada file yang disediakan atau anda bisa menimpa langsung modul kosong pada proyek tersebut.
Kenapa error pass dijalankan di ConsoleAplication VB2010 ?
Dibagian :
Protected Sub BaseEncrypt(ByRef unHiRef As UInteger, ByRef unLoRef As UInteger)
Dim unHi As UInteger = unHiRef
Dim unLo As UInteger = unLoRef
Dim sbox1 As UInteger() = m_sbox1
Dim sbox2 As UInteger() = m_sbox2
Dim sbox3 As UInteger() = m_sbox3
Dim sbox4 As UInteger() = m_sbox4
Dim pbox As UInteger() = m_pbox
unHi = unHi Xor pbox(0)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(1)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(2)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(3)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(4)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(5)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(6)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(7)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(8)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(9)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(10)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(11)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(12)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(13)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(14)
unLo = unLo Xor (((sbox1(CInt(unHi >> 24)) + sbox2(CInt((unHi >> 16) And &HFF))) Xor sbox3(CInt((unHi >> 8) And &HFF))) + sbox4(CInt(unHi And &HFF))) Xor pbox(15)
unHi = unHi Xor (((sbox1(CInt(unLo >> 24)) + sbox2(CInt((unLo >> 16) And &HFF))) Xor sbox3(CInt((unLo >> 8) And &HFF))) + sbox4(CInt(unLo And &HFF))) Xor pbox(16)
unLoRef = unHi
unHiRef = unLo Xor pbox(17)
End Sub
Karena alasan aritmatikan gituh.. padahal saya masuk input dan key seperti contoh.
saya menjalankan console nya di Visual Studio 2010. tidak ada error dan bisa di running hanya tidak bisa melakukan proses enkripsi.
Pada saat saya mencoba kembali skrip ini, saya tetap dapat menjalankan skrip ini tanpa mengalami kendala. Pada saat proses enkripsi, apakah yang terjadi pada saat setelah anda memasukkan kalimat dan kata kunci? Apakah muncul pesan kesalahan tertentu?
ya muncul pesan kesalahan setiap saya memasukkan kalimat dan kata kunci, Saya sudah mencoba dengan kalimat dan kata kunci seperti contoh yang di atas, dan juga kalimat dan kata kunci di contoh soal saya, hasil nya tetap sama tidak bisa di enkripsi
bisa dilihat contoh di bawah ini.
https://drive.google.com/file/d/1SP3pAWz2ZUCnxkv1v5enTWSV7V3l9vPk/view?usp=sharing
Baik, terima kasih atas laporan yang diberikan. Akan tetapi sangat sulit untuk membetulkan error tersebut karena skrip yang saya miliki berjalan dengan sangat baik walaupun saya melakukan pengujian dengan kalimat dan kata kunci yang bervariasi dan cukup panjang.
Dapatkah anda melakukan pengujian dengan menggunakan 1 karakter, sebagai contoh kalimat adalah “a” dan kata kunci adalah “1” (tanpa tanda petik)? Apakah masih terdapat kesalahan apabila menggunakan pengujian tersebut? Jika masih terdapat kesalahan yang sama, dapatkah anda menunjukkan isi dari semua variabel yang digunakan (unHi, unLo, sbox1, sbox2, sbox3, sbox4, pbox)?
Mohon maaf, saya ingin bertanya. Kenapa pada saat saya run tidak muncul jendela hitamnya ? Hanya muncul kilatan seperti berkedip saja padahal saya sudah timpa filenya dengan menggunakan Console Application juga. Terima kasih
Skrip ini saya rancang tanpa ketergantungan dengan library tertentu, sehingga seharusnya apabila menggunakan proyek bertipe “Console Application” skrip tersebut dapat berjalan dengan benar. Skrip ini masih berjalan dengan baik pada saat saya periksa kembali, sehingga saya tidak dapat mereplika kesalahan yang anda laporkan. Silahkan mencoba untuk melakukan debug run secara baris per baris untuk mengetahui dimanakah pembacaan skrip berhenti yang mengakibatkan program langsung menutup dengan sendirinya.