<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=UUencode</id>
	<title>UUencode - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=UUencode"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=UUencode&amp;action=history"/>
	<updated>2026-05-19T05:39:48Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=UUencode&amp;diff=68286&amp;oldid=prev</id>
		<title>imported&gt;Wurgl: &lt;pre&gt; statt einrückung und nowiki</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=UUencode&amp;diff=68286&amp;oldid=prev"/>
		<updated>2025-02-10T13:43:56Z</updated>

		<summary type="html">&lt;p&gt;&amp;lt;pre&amp;gt; statt einrückung und nowiki&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;UUencode&amp;#039;&amp;#039;&amp;#039; war das erste verbreitete Programm, das es ermöglichte, [[Binärdatei]]en (also z.&amp;amp;nbsp;B. Bilder oder Programme) so umzuwandeln, dass sie nur noch aus „druckbaren ASCII-Zeichen“ bestehen und dadurch problemlos per [[E-Mail]] verschickt werden konnten, in denen nur [[American Standard Code for Information Interchange|ASCII]]-Zeichen erlaubt sind.&lt;br /&gt;
&lt;br /&gt;
== Geschichte ==&lt;br /&gt;
UUencode wurde 1980 von [[Mary Ann Horton]] entwickelt.&amp;lt;ref&amp;gt;[https://www.tuhs.org/cgi-bin/utree.pl?file=4BSD/usr/man/cat1/uuencode.1c tuhs.org]&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Das UU steht für die Wurzeln in [[Unix]]. Das UU in UUencode und -decode steht ebenso wie das UU bei [[Unix to Unix Copy|UUcp]] für &amp;#039;&amp;#039;&amp;#039;U&amp;#039;&amp;#039;&amp;#039;NIX&amp;lt;!--sic--&amp;gt; to &amp;#039;&amp;#039;&amp;#039;U&amp;#039;&amp;#039;&amp;#039;NIX&amp;lt;!--sic--&amp;gt; &amp;#039;&amp;#039;copy protocol&amp;#039;&amp;#039;, also die Übertragung von einem UNIX-Computer zu einem anderen UNIX-Computer.&lt;br /&gt;
&lt;br /&gt;
Das Prinzip ist dabei ähnlich wie beim heute für E-Mail-Anhänge üblichen [[Base64]]-Verfahren: Drei Bytes der Binärdatei (=24&amp;amp;nbsp;bit) werden auf viermal 6&amp;amp;nbsp;Bit aufgeteilt und den 6-bit-Werten werden druckbare ASCII-Zeichen zugeordnet. Erste Versionen von UUencode benutzten dabei einfach die ASCII-Zeichen mit den Werten 32 bis 95.&lt;br /&gt;
&lt;br /&gt;
Da das [[Leerzeichen]] (ASCII-Wert 32) den [[E-Mail]]-Versand oft nicht heil übersteht, wurde stattdessen das ASCII-Zeichen mit dem Wert 96 (&amp;quot;&amp;lt;code&amp;gt;`&amp;lt;/code&amp;gt;&amp;quot;) verwendet.&lt;br /&gt;
&lt;br /&gt;
== Dateiformat ==&lt;br /&gt;
UUencode benutzt ein spezielles Format für die kodierte Datei:&lt;br /&gt;
: &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;begin&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt; &amp;#039;&amp;#039;modus&amp;amp;nbsp;&amp;amp;nbsp;dateiname&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;#039;&amp;#039;länge&amp;amp;nbsp;&amp;amp;nbsp;daten&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;#039;&amp;#039;länge&amp;amp;nbsp;&amp;amp;nbsp;daten&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;#039;&amp;#039;...&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;#039;&amp;#039;länge&amp;amp;nbsp;&amp;amp;nbsp;daten&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;`&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;&lt;br /&gt;
: &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;end&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Als &amp;#039;&amp;#039;modus&amp;#039;&amp;#039; werden dabei die Dateirechte, wie sie unter Unix üblich sind, als 3- oder 4-stellige [[Oktalsystem|Oktalzahl]] geschrieben. Der &amp;#039;&amp;#039;Dateiname&amp;#039;&amp;#039; ist der Name der Originaldatei, ohne Verzeichnis.&lt;br /&gt;
&lt;br /&gt;
Jede Datenzeile beginnt mit einer 1-Byte-Längenangabe, die angibt, wie viele Originalbytes in dieser Zeile kodiert worden sind. Diese Längenangabe ist eine Zahl zwischen 1 und 63 und wird dabei ebenfalls uu-kodiert, also als Zeichen von &amp;quot;&amp;lt;code&amp;gt;!&amp;lt;/code&amp;gt;&amp;quot; bis &amp;quot;&amp;lt;code&amp;gt;_&amp;lt;/code&amp;gt;&amp;quot;.&lt;br /&gt;
Üblich sind 45 Byte (also der Wert &amp;quot;&amp;lt;code&amp;gt;M&amp;lt;/code&amp;gt;&amp;quot;) die in 60 Zeichen kodiert werden.&lt;br /&gt;
&lt;br /&gt;
Um das Ende der Datei anzuzeigen, muss stets eine „Leerzeile“ kodiert werden,&lt;br /&gt;
die nur das Längenbyte 0 (kodiert &amp;quot;&amp;lt;code&amp;gt;`&amp;lt;/code&amp;gt;&amp;quot;) enthält. Abschließend folgt eine Zeile mit dem Schlüsselwort &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;end&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Kodierungsverfahren ==&lt;br /&gt;
&lt;br /&gt;
Drei Bytes Quelldaten werden durch &amp;lt;code&amp;gt;uuencode&amp;lt;/code&amp;gt; in vier Bytes kodiert. Die Daten liegen in der uuencodierten Datei in den unteren sechs Bits der Bytes, die oberen Bits werden durch die Kodierung gesetzt:&lt;br /&gt;
&lt;br /&gt;
     unkodierter Bitstrom    ↔    kodierter Bitstrom&lt;br /&gt;
 aaaaaaaa bbbbbbbb cccccccc  ↔  0kaaaaaa 0kaabbbb 0kbbbbcc 0kcccccc&lt;br /&gt;
&lt;br /&gt;
Zur Kodierung werden die neuen Sechsergruppen &amp;quot;00eeeeee&amp;quot; zunächst mit 32 [[XOR]]-verknüpft.&lt;br /&gt;
Ist das daraus resultierende Ergebnis ≤ 32, so wird das Bit&amp;amp;nbsp;k gesetzt.&lt;br /&gt;
&lt;br /&gt;
 uncodiert                      (XOR 32)                   (k setzen?)                        codiert&lt;br /&gt;
 [0]     = [00000000]              →            [00100000]    -ja→               [01100000] =    [96]&lt;br /&gt;
 [1,31]  = [00000001,00011111]     →   [00100001,00111111]   -nein→     [00100001,00111111] = [33,63]&lt;br /&gt;
 [32,63] = [00100000,00111111]     →   [00000000,00011111]    -ja→      [01000000,01011111] = [64,95]&lt;br /&gt;
&lt;br /&gt;
Anders ausgedrückt: Für 0 ist das Ergebnis 96, für alle anderen muss 32 addiert werden.&lt;br /&gt;
&lt;br /&gt;
Die Dekodierung der Daten arbeitet umgekehrt, vier Bytes Quelldaten werden durch &amp;lt;code&amp;gt;uudecode&amp;lt;/code&amp;gt; in drei Bytes decodiert.&lt;br /&gt;
Ist in den Quelldaten das Bit&amp;amp;nbsp;k gesetzt, ist dieses zu entfernen.&lt;br /&gt;
Das daraus resultierende Ergebnis wird dann mit 32 [[XOR]]-verknüpft.&lt;br /&gt;
&lt;br /&gt;
 codiert                      (k entfernen)                 (XOR 32)                        uncodiert&lt;br /&gt;
 [96]    = [01100000]             -ja→            [00100000]   →                [00000000] =      [0]&lt;br /&gt;
 [33,63] = [00100001,00111111]   -nein→  [00100001,00111111]   →       [00000001,00011111] =   [1,31]&lt;br /&gt;
 [64,95] = [01000000,01011111]    -ja→   [00000000,00011111]   →       [00100000,00111111] =  [32,63]&lt;br /&gt;
&lt;br /&gt;
Anders ausgedrückt: Für 96 ist das Ergebnis 0, für alle anderen muss 32 subtrahiert werden.&lt;br /&gt;
&lt;br /&gt;
     kodierter Bitstrom               ↔     unkodierter Bitstrom&lt;br /&gt;
 0kaaaaaa 0kaabbbb 0kbbbbcc 0kcccccc  ↔  aaaaaaaa bbbbbbbb cccccccc&lt;br /&gt;
&lt;br /&gt;
== Beispiel ==&lt;br /&gt;
Ein Textabsatz von oben diene als Eingabe:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Geschichte&lt;br /&gt;
&lt;br /&gt;
Das UU steht für die Wurzeln in UNIX. Das UU in UUencode und -decode steht&lt;br /&gt;
ebenso wie das UU bei UUcp für UNIX to UNIX copy protocol. Also die Übertragung&lt;br /&gt;
von einem UNIX-Computer zu einem anderen UNIX-Computer.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Die UUencodierung macht daraus:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
begin 644 uuencode-Test.txt&lt;br /&gt;
M1V5S8VAI8VAT90T*#0I$87,@554@&amp;lt;W1E:&amp;#039;0@9OQR(&amp;amp;1I92!7=7)Z96QN(&amp;amp;EN&lt;br /&gt;
M(%5.25@N($1A&amp;lt;R!552!I;B!5565N8V]D92!U;F0@+61E8V]D92!S=&amp;amp;5H=&amp;quot;`-&lt;br /&gt;
M&amp;quot;F5B96YS;R!W:64@9&amp;amp;%S(%55(&amp;amp;)E:2!556-P(&amp;amp;;\&amp;lt;B!53DE8(&amp;#039;1O(%5.25@@&lt;br /&gt;
M8V]P&amp;gt;2!P&amp;lt;F]T;V-O;&amp;quot;X@06QS;R!D:64@W&amp;amp;)E&amp;lt;G1R86=U;F&amp;lt;@#0IV;VX@96EN&lt;br /&gt;
M96T@54Y)6&amp;quot;U#;VUP=71E&amp;lt;B!Z=2!E:6YE;2!A;F1E&amp;lt;F5N(%5.25@M0V]M&amp;lt;&amp;#039;5T&lt;br /&gt;
%97(N#0H`&lt;br /&gt;
`&lt;br /&gt;
end&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== XXencode ==&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;XXencode&amp;#039;&amp;#039;&amp;#039; arbeitet genauso wie UUencode, verwendet aber ausschließlich Buchstaben und Ziffern und die beiden Sonderzeichen Plus&amp;amp;nbsp;(+) und Minus&amp;amp;nbsp;(-). Dies soll das Risiko, dass einige Zeichen in der Textdatei durch automatische Zeichensatzumwandlungen (z.&amp;amp;nbsp;B. von ASCII nach [[Extended Binary Coded Decimals Interchange Code|EBCDIC]]) während der Übertragung irreparabel beschädigt werden, minimieren.&lt;br /&gt;
&lt;br /&gt;
Zusätzlich besteht bei einigen xxencode-Versionen die Möglichkeit, optional eine Liste sämtlicher verwendeter Zeichen mitzuschicken. Wenn diese Liste durch fehlerhafte Zeichensatzumwandlungen ebenfalls modifiziert wird, kann der Empfänger dies erkennen und die Datei trotzdem korrekt dekodieren, solange die Modifizierungen [[Bijektivität|umkehrbar eindeutig]] sind.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|+ Kodierungstabelle von XXencode&lt;br /&gt;
|- class=&amp;quot;hintergrundfarbe6&amp;quot;&lt;br /&gt;
! Wert&lt;br /&gt;
! Zeichen&lt;br /&gt;
|rowspan=17 style=&amp;quot;width:1px;background:#000000;padding:0px;&amp;quot;|&lt;br /&gt;
! Wert&lt;br /&gt;
! Zeichen&lt;br /&gt;
|rowspan=17 style=&amp;quot;width:1px;background:#000000;padding:0px;&amp;quot;|&lt;br /&gt;
! Wert&lt;br /&gt;
! Zeichen&lt;br /&gt;
|rowspan=17 style=&amp;quot;width:1px;background:#000000;padding:0px;&amp;quot;|&lt;br /&gt;
! Wert&lt;br /&gt;
! Zeichen&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &amp;lt;code&amp;gt;+&amp;lt;/code&amp;gt; || 16 || &amp;lt;code&amp;gt;E&amp;lt;/code&amp;gt; || 32 || &amp;lt;code&amp;gt;U&amp;lt;/code&amp;gt; || 48 || &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 1 || &amp;lt;code&amp;gt;-&amp;lt;/code&amp;gt; || 17 || &amp;lt;code&amp;gt;F&amp;lt;/code&amp;gt; || 33 || &amp;lt;code&amp;gt;V&amp;lt;/code&amp;gt; || 49 || &amp;lt;code&amp;gt;l&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 2 || &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; || 18 || &amp;lt;code&amp;gt;G&amp;lt;/code&amp;gt; || 34 || &amp;lt;code&amp;gt;W&amp;lt;/code&amp;gt; || 50 || &amp;lt;code&amp;gt;m&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 3 || &amp;lt;code&amp;gt;1&amp;lt;/code&amp;gt; || 19 || &amp;lt;code&amp;gt;H&amp;lt;/code&amp;gt; || 35 || &amp;lt;code&amp;gt;X&amp;lt;/code&amp;gt; || 51 || &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 4 || &amp;lt;code&amp;gt;2&amp;lt;/code&amp;gt; || 20 || &amp;lt;code&amp;gt;I&amp;lt;/code&amp;gt; || 36 || &amp;lt;code&amp;gt;Y&amp;lt;/code&amp;gt; || 52 || &amp;lt;code&amp;gt;o&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 5 || &amp;lt;code&amp;gt;3&amp;lt;/code&amp;gt; || 21 || &amp;lt;code&amp;gt;J&amp;lt;/code&amp;gt; || 37 || &amp;lt;code&amp;gt;Z&amp;lt;/code&amp;gt; || 53 || &amp;lt;code&amp;gt;p&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 6 || &amp;lt;code&amp;gt;4&amp;lt;/code&amp;gt; || 22 || &amp;lt;code&amp;gt;K&amp;lt;/code&amp;gt; || 38 || &amp;lt;code&amp;gt;a&amp;lt;/code&amp;gt; || 54 || &amp;lt;code&amp;gt;q&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 7 || &amp;lt;code&amp;gt;5&amp;lt;/code&amp;gt; || 23 || &amp;lt;code&amp;gt;L&amp;lt;/code&amp;gt; || 39 || &amp;lt;code&amp;gt;b&amp;lt;/code&amp;gt; || 55 || &amp;lt;code&amp;gt;r&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 8 || &amp;lt;code&amp;gt;6&amp;lt;/code&amp;gt; || 24 || &amp;lt;code&amp;gt;M&amp;lt;/code&amp;gt; || 40 || &amp;lt;code&amp;gt;c&amp;lt;/code&amp;gt; || 56 || &amp;lt;code&amp;gt;s&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| 9 || &amp;lt;code&amp;gt;7&amp;lt;/code&amp;gt; || 25 || &amp;lt;code&amp;gt;N&amp;lt;/code&amp;gt; || 41 || &amp;lt;code&amp;gt;d&amp;lt;/code&amp;gt; || 57 || &amp;lt;code&amp;gt;t&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|10 || &amp;lt;code&amp;gt;8&amp;lt;/code&amp;gt; || 26 || &amp;lt;code&amp;gt;O&amp;lt;/code&amp;gt; || 42 || &amp;lt;code&amp;gt;e&amp;lt;/code&amp;gt; || 58 || &amp;lt;code&amp;gt;u&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|11 || &amp;lt;code&amp;gt;9&amp;lt;/code&amp;gt; || 27 || &amp;lt;code&amp;gt;P&amp;lt;/code&amp;gt; || 43 || &amp;lt;code&amp;gt;f&amp;lt;/code&amp;gt; || 59 || &amp;lt;code&amp;gt;v&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|12 || &amp;lt;code&amp;gt;A&amp;lt;/code&amp;gt; || 28 || &amp;lt;code&amp;gt;Q&amp;lt;/code&amp;gt; || 44 || &amp;lt;code&amp;gt;g&amp;lt;/code&amp;gt; || 60 || &amp;lt;code&amp;gt;w&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|13 || &amp;lt;code&amp;gt;B&amp;lt;/code&amp;gt; || 29 || &amp;lt;code&amp;gt;R&amp;lt;/code&amp;gt; || 45 || &amp;lt;code&amp;gt;h&amp;lt;/code&amp;gt; || 61 || &amp;lt;code&amp;gt;x&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|14 || &amp;lt;code&amp;gt;C&amp;lt;/code&amp;gt; || 30 || &amp;lt;code&amp;gt;S&amp;lt;/code&amp;gt; || 46 || &amp;lt;code&amp;gt;i&amp;lt;/code&amp;gt; || 62 || &amp;lt;code&amp;gt;y&amp;lt;/code&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
|15 || &amp;lt;code&amp;gt;D&amp;lt;/code&amp;gt; || 31 || &amp;lt;code&amp;gt;T&amp;lt;/code&amp;gt; || 47 || &amp;lt;code&amp;gt;j&amp;lt;/code&amp;gt; || 63 || &amp;lt;code&amp;gt;z&amp;lt;/code&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Verwandte Themen ==&lt;br /&gt;
* [[7plus]] – im Amateurfunk eingesetztes effizienteres und zudem fehlersicheres Kodierungsverfahren&lt;br /&gt;
* [[Kermit (Software)|Kermit]] – Protokoll, das Binärzeichen ebenfalls auf ASCII-Zeichen abbildet.&lt;br /&gt;
* [[Base64]] – Kodierung nach [[Multipurpose Internet Mail Extensions|MIME]], das in E-Mails verwendet wird, um Binärdateien zu übertragen.&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://www.webutils.pl/UUencode Online UUencode / UUdecode tool]&lt;br /&gt;
* [http://www.webutils.pl/XXencode Online XXencode / XXdecode tool]&lt;br /&gt;
* [http://www.gnu.org/software/sharutils/ GNU sharutils] – Das sharutils Softwarepaket der Free Software Foundation enthält uuencode und uudecode.&lt;br /&gt;
* [http://www.fpx.de/fp/Software/UUDeview/ UUDeview] – Ein Open-Source Programm zum Encodieren und Decodieren von Base64, BinHex für Unix/Windows/DOS&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:E-Mail]]&lt;br /&gt;
[[Kategorie:Zeichenkodierung]]&lt;br /&gt;
[[Kategorie:Datenformat]]&lt;br /&gt;
[[Kategorie:Abkürzung]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Wurgl</name></author>
	</entry>
</feed>