vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Dateisystem · Dateien lesen/schreiben   |   VB-Versionen: VB.NET07.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 OtterBewertung:  Views:  18.328 
www.tools4vb.deSystem:  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



Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.