Rubrik: Dateisystem · Dateien lesen/schreiben | VB-Versionen: VB.NET | 07.08.06 |
Daten ver- und entschlüsseln (VB 2005) Mit Hilfe der System.Cryptography-Klasse aus dem .NET Framework 2.0 lassen sich Daten sehr einfach ver- und entschlüsseln. | ||
Autor: Dieter Otter | Bewertung: | Views: 18.328 |
www.tools4vb.de | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Mit Hilfe der neuen System.Cryptography.ProtectedData - Klasse aus dem .NET Framework 2.0 lassen sich Daten sehr einfach ver- und entschlüsseln. Fügen Sie dem Projekt hierzu zunächst den Verweis auf "System.Security" hinzu.
Nachfolgender Code veranschaulicht die Verwendung der ProtectedData-Klasse. Hierbei wird über die Prozedur "EncryptData" ein beliebiger String verschlüsselt in eine Datei gespeichert und über die Funktion "DecryptData" wieder ausgelesen und entschlüsselt.
Fügen Sie der Form zwei Buttons (Button1, Button2) und eine TextBox hinzu.
Imports System.Security.Cryptography Public Class Form1
' Daten verschlüsseln Public Sub EncryptData(ByVal sData As String, ByVal sFile As String) ' MemoryStream erstellen und Original-Daten in den Stream schreiben Dim oStream As New IO.MemoryStream With New IO.StreamWriter(oStream) .Write(sData) .Close() End With ' Daten verschlüsseln Dim bData() As Byte bData = ProtectedData.Protect( _ oStream.ToArray(), Nothing, DataProtectionScope.CurrentUser) ' verschlüsselte Daten in Datei speichern My.Computer.FileSystem.WriteAllBytes(sFile, bData, False) End Sub
' Daten entschlüsseln Public Function DecryptData(ByVal sFile As String) As String ' Datei mit verschlüsselten Daten auslesen Dim bData() As Byte bData = My.Computer.FileSystem.ReadAllBytes(sFile) ' Daten entschlüsseln bData = ProtectedData.Unprotect(bData, Nothing, _ DataProtectionScope.CurrentUser) ' in String umwandeln und als Funktionswert zurückgeben Dim oStream As New IO.MemoryStream(bData) With New IO.StreamReader(oStream) Return .ReadToEnd() .Close() End With End Function
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) _ Handles Button1.Click ' Text der TextBox verschlüsseln EncryptData(TextBox1.Text, "d:\test.dat") End Sub
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) _ Handles Button2.Click ' verschlüsselten Text aus Datei auslesen und entschlüsseln Dim sText As String sText = DecryptData("d:\test.dat") MsgBox(sText) End Sub
End Class