Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
Panduan ini menunjukkan kepada Anda cara menggunakan DESCryptoServiceProvider kelas untuk mengenkripsi dan mendekripsi string menggunakan versi penyedia layanan kriptografi (CSP) dari algoritma Standar Enkripsi Data Triple (TripleDES). Langkah pertama adalah membuat kelas pembungkus sederhana yang merangkum algoritma 3DES dan menyimpan data terenkripsi sebagai string yang dikodekan base-64. Kemudian, pembungkus tersebut digunakan untuk menyimpan data pengguna privat dengan aman dalam file teks yang dapat diakses publik.
Anda dapat menggunakan enkripsi untuk melindungi rahasia pengguna (misalnya, kata sandi) dan untuk membuat kredensial tidak dapat dibaca oleh pengguna yang tidak sah. Ini dapat melindungi identitas pengguna yang berwenang dari pencurian, melindungi aset pengguna, dan memastikan integritas sehingga tindakan tersebut tidak dapat disangkal. Enkripsi juga dapat melindungi data pengguna agar tidak diakses oleh pengguna yang tidak sah.
Untuk informasi selengkapnya, lihat Layanan Kriptografi.
Penting
Algoritma Rijndael (sekarang dikenal sebagai Advanced Encryption Standard [AES]) dan Triple Data Encryption Standard (3DES) memberikan keamanan yang lebih besar daripada DES karena lebih intensif secara komputasi. Untuk informasi lebih lanjut, lihat DES dan Rijndael.
Untuk membuat pembungkus enkripsi
Simple3Des
Buat kelas untuk merangkum metode enkripsi dan dekripsi.Public NotInheritable Class Simple3Des End Class
Tambahkan impor namespace kriptografi ke awal file yang berisi
Simple3Des
kelas .Imports System.Security.Cryptography
Di kelas
Simple3Des
, tambahkan bidang privat untuk menyimpan penyedia layanan kriptografi 3DES.Private TripleDes As New TripleDESCryptoServiceProvider
Tambahkan metode privat yang membuat array byte dengan panjang tertentu dari hash kunci yang ditentukan.
Private Function TruncateHash( ByVal key As String, ByVal length As Integer) As Byte() Dim sha1 As New SHA1CryptoServiceProvider ' Hash the key. Dim keyBytes() As Byte = System.Text.Encoding.Unicode.GetBytes(key) Dim hash() As Byte = sha1.ComputeHash(keyBytes) ' Truncate or pad the hash. ReDim Preserve hash(length - 1) Return hash End Function
Tambahkan konstruktor untuk menginisialisasi penyedia layanan kriptografi 3DES.
Parameter
key
mengontrolEncryptData
metode danDecryptData
.Sub New(ByVal key As String) ' Initialize the crypto provider. TripleDes.Key = TruncateHash(key, TripleDes.KeySize \ 8) TripleDes.IV = TruncateHash("", TripleDes.BlockSize \ 8) End Sub
Tambahkan metode publik yang mengenkripsi string.
Public Function EncryptData( ByVal plaintext As String) As String ' Convert the plaintext string to a byte array. Dim plaintextBytes() As Byte = System.Text.Encoding.Unicode.GetBytes(plaintext) ' Create the stream. Dim ms As New System.IO.MemoryStream ' Create the encoder to write to the stream. Dim encStream As New CryptoStream(ms, TripleDes.CreateEncryptor(), System.Security.Cryptography.CryptoStreamMode.Write) ' Use the crypto stream to write the byte array to the stream. encStream.Write(plaintextBytes, 0, plaintextBytes.Length) encStream.FlushFinalBlock() ' Convert the encrypted stream to a printable string. Return Convert.ToBase64String(ms.ToArray) End Function
Tambahkan metode publik yang mendekripsi string.
Public Function DecryptData( ByVal encryptedtext As String) As String ' Convert the encrypted text string to a byte array. Dim encryptedBytes() As Byte = Convert.FromBase64String(encryptedtext) ' Create the stream. Dim ms As New System.IO.MemoryStream ' Create the decoder to write to the stream. Dim decStream As New CryptoStream(ms, TripleDes.CreateDecryptor(), System.Security.Cryptography.CryptoStreamMode.Write) ' Use the crypto stream to write the byte array to the stream. decStream.Write(encryptedBytes, 0, encryptedBytes.Length) decStream.FlushFinalBlock() ' Convert the plaintext stream to a string. Return System.Text.Encoding.Unicode.GetString(ms.ToArray) End Function
Kelas pembungkus sekarang dapat digunakan untuk melindungi aset pengguna. Dalam contoh ini, digunakan untuk menyimpan data pengguna privat dengan aman dalam file teks yang dapat diakses publik.
Untuk menguji pembungkus enkripsi
Di kelas terpisah, tambahkan metode yang menggunakan metode pembungkus
EncryptData
untuk mengenkripsi string dan menulisnya ke folder Dokumen Saya pengguna.Sub TestEncoding() Dim plainText As String = InputBox("Enter the plain text:") Dim password As String = InputBox("Enter the password:") Dim wrapper As New Simple3Des(password) Dim cipherText As String = wrapper.EncryptData(plainText) MsgBox("The cipher text is: " & cipherText) My.Computer.FileSystem.WriteAllText( My.Computer.FileSystem.SpecialDirectories.MyDocuments & "\cipherText.txt", cipherText, False) End Sub
Tambahkan fungsi yang membaca string terenkripsi dari folder My Documents pengguna dan mendekripsi string tersebut dengan metode pembungkus
DecryptData
.Sub TestDecoding() Dim cipherText As String = My.Computer.FileSystem.ReadAllText( My.Computer.FileSystem.SpecialDirectories.MyDocuments & "\cipherText.txt") Dim password As String = InputBox("Enter the password:") Dim wrapper As New Simple3Des(password) ' DecryptData throws if the wrong password is used. Try Dim plainText As String = wrapper.DecryptData(cipherText) MsgBox("The plain text is: " & plainText) Catch ex As System.Security.Cryptography.CryptographicException MsgBox("The data could not be decrypted with the password.") End Try End Sub
Tambahkan kode antarmuka pengguna untuk memanggil metode
TestEncoding
danTestDecoding
.Jalankan aplikasi.
Ketika Anda menguji aplikasi, perhatikan bahwa aplikasi tidak akan mendekripsi data jika Anda memberikan kata sandi yang salah.