| |
VB.NET - FortgeschritteneRe: Suche Gegenstück zu "Datei nach Base64 codieren und speichern" | | | Autor: J?rg Trapp | Datum: 29.05.19 18:52 |
| Ich suche den passenden Code um eine mit Base64 codierte
Datei, wieder zurück in die ursprüngliche Datei zu speichern.
Gruß
Jörg Trapp | |
Re: Suche Gegenstück zu "Datei nach Base64 codieren und speichern" | | | Autor: Manfred X | Datum: 31.05.19 09:32 |
| Hallo!
Encoding mußt Du noch checken ....
Private Shared Function FileFromBase64(ByVal sFileIn As String,
sFileOut As String) As Boolean
If Not IO.File.Exists(sFileIn) Then Return False
Try
Dim str64 As String = IO.File.ReadAllText(sFileIn)
Dim chars() As Char = str64.ToCharArray
Dim bytes As Byte() =
System.Convert.FromBase64CharArray(chars, 0, chars.Length)
Dim stb As New Text.StringBuilder
For i As Integer = 0 To bytes.Length - 1 Step 1
stb.Append(ChrW(bytes(i)))
Next i
IO.File.WriteAllText(sFileOut, stb.ToString)
Return True
Catch
Return False
End Try
End Function Oder so:
Dim str64 As String = IO.File.ReadAllText(sFileIn)
Dim bytes() As Byte = System.Convert.FromBase64String(str64)
IO.File.WriteAllText(sFileOut, System.Text.Encoding.UTF8.GetString(bytes))
Beitrag wurde zuletzt am 31.05.19 um 09:54:57 editiert. | |
Re: Suche Gegenstück zu "Datei nach Base64 codieren und speichern" | | | Autor: J?rg Trapp | Datum: 31.05.19 14:04 |
| Hallo "Manfred X",
vielen Dank für den Code. Leider funktioniert er nicht.
Wenn ich z.B. eine PDF oder DOCX Dateien hin und her
speichere, kommt am Ende eine defekte Datei raus.
Gruß
Jörg Trapp
Private Function FileToBase64(ByVal sFileIn As String, ByVal sFileOut As _
String) As Boolean
Dim bResult As Boolean = False
Dim oReader As IO.FileStream = Nothing
Dim oWriter As IO.StreamWriter = Nothing
Try
' Falls Output-Datei bereits existiert, löschen
If IO.File.Exists(sFileOut) Then IO.File.Delete(sFileOut)
' Input-Datei zum Lesen öffnen
oReader = New IO.FileStream(sFileIn, IO.FileMode.Open, _
IO.FileAccess.Read)
' Output-Datei zum Schreiben öffnen
oWriter = New IO.StreamWriter(sFileOut, False, _
System.Text.Encoding.UTF8)
' Datei blockweise einlesen
Dim nBytes As Integer
Dim Buffer(56) As Byte
Do
nBytes = oReader.Read(Buffer, 0, Buffer.Length)
If nBytes > 0 Then
' Inhalt nach Base64 codieren und in Output-Datei schreiben
oWriter.WriteLine(System.Convert.ToBase64String(Buffer, 0, _
nBytes))
End If
Loop Until nBytes = 0
' Streams (Dateien) schließen
oReader.Close()
oWriter.Close()
bResult = True
Catch ex As Exception
If oReader IsNot Nothing Then oReader.Close()
If oWriter IsNot Nothing Then oWriter.Close()
End Try
Return bResult
End Function
Private Function FileFromBase64(ByVal sFileIn As String, sFileOut As String) As _
Boolean
If Not IO.File.Exists(sFileIn) Then Return False
Try
Dim str64 As String = IO.File.ReadAllText(sFileIn)
Dim bytes() As Byte = System.Convert.FromBase64String(str64)
IO.File.WriteAllText(sFileOut, System.Text.Encoding.UTF8.GetString( _
bytes))
Return True
Catch
Return False
End Try
End Function '-------------------------------------------------------------
FileToBase64("Alt.docx", "Alt.docx.dat")
FileToBase64("Alt.pdf", "Alt.pdf.dat")
'-------------------------------------------------------------
FileFromBase64("Alt.docx.dat", "Neu.docx")
FileFromBase64("Alt.pdf.dat", "Neu.pdf")
'------------------------------------------------------------- | |
Re: Suche Gegenstück zu "Datei nach Base64 codieren und speichern" | | | Autor: Manfred X | Datum: 31.05.19 15:07 |
| Erkläre, was Du erreichen möchtest.
Die Base64-Codierung wandelt alphanumerische Zeichenfolgen (Texte) in Bytefolgen um.
Bei Docx- oder PDF-Dateien handelt es sich um strukturiert codierte Muster, deren
binäre Darstellung mit Zeichenfolgen nichts zu tun hat.
Im übrigen ist das eine simple Umkehrfunktion:
Dim bytes() As Byte
bytes = IO.File.ReadAllBytes("G:\daten\irgendeine Datei")
Dim str As String = Convert.ToBase64String(bytes, 0, bytes.Length)
Dim bytes2() As Byte = Convert.FromBase64String(str)
IO.File.WriteAllBytes("G:\daten\Datei decodiert", bytes2)
For i As Integer = 0 To bytes.Length - 1
If bytes2(i) <> bytes(i) Then Stop
Next i
Beitrag wurde zuletzt am 31.05.19 um 15:26:09 editiert. | |
Dateiinhalt mit Base64String codieren und decodieren | | | Autor: Manfred X | Datum: 31.05.19 15:52 |
| Private Function FileToB64(FileIn As String, Fileout As String) As Boolean
Try
IO.File.Delete(Fileout)
IO.File.WriteAllText(Fileout,
Convert.ToBase64String(IO.File.ReadAllBytes(FileIn)), _
System.Text.Encoding.UTF8)
Return True
Catch ex As Exception
Return False
End Try
End Function
Private Function FileFromB64(FileIn As String, Fileout As String) As Boolean
Try
IO.File.Delete(Fileout)
IO.File.WriteAllBytes(Fileout,
Convert.FromBase64String(IO.File.ReadAllText(FileIn, _
System.Text.Encoding.UTF8)))
Return True
Catch
Return False
End Try
End Function | |
Re: Dateiinhalt mit Base64String codieren und decodieren | | | Autor: J?rg Trapp | Datum: 31.05.19 16:04 |
| Hallo Manfred X,
ich möchte unterschiedliche Dateianhänge in eine
XML Datei abspeichern. Das soll einfacher sein,
wenn diese als Base64 vorliegen.
Gruß
Jörg Trapp | |
Re: Dateiinhalt mit Base64String codieren und decodieren | | | Autor: Kuno60 | Datum: 31.05.19 22:30 |
| J?rg Trapp schrieb:
Zitat: | | ich möchte unterschiedliche Dateianhänge in eine
XML Datei abspeichern. Das soll einfacher sein,
wenn diese als Base64 vorliegen. | |
Das ist nicht nur einfacher, sondern auch notwendig, wenn man binären Inhalt in eine Textdatei einbetten will (XML ist eine Textdatei).
Das Beispiel aus den Tipps hat einen kleinen Fehler. Es schreibt aller 56 Byte ein Zeilenumbruchzeichen (mit oWriter.WriteLine) in die Datei. Dies müsste man beim Lesen wieder Rückgängig machen.
Das letzte Beispiel von Manfred funktioniert.
Tipp: Man kann auch den binären Inhalt direkt in XML ein- und auslesen.
System.Xml.XmlReader
ReadContentAsBase64(Byte()) As Integer
System.Xml.XmlWriter
WriteBase64(Byte()) | |
| Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
|
|
sevWizard für VB5/6
Professionelle Assistenten im Handumdrehen
Erstellen Sie eigene Assistenten (Wizards) im Look & Feel von Windows 2000/XP - mit allem Komfort und zwar in Windeseile :-) Weitere InfosTipp des Monats TOP Entwickler-Paket
TOP-Preis!!
Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR...
Jetzt nur 599,00 EURWeitere Infos
|
|
|
Copyright ©2000-2024 vb@rchiv Dieter Otter Alle 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.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|