<?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=Remote_Framebuffer_Protocol</id>
	<title>Remote Framebuffer Protocol - 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=Remote_Framebuffer_Protocol"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Remote_Framebuffer_Protocol&amp;action=history"/>
	<updated>2026-05-16T08:44:06Z</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=Remote_Framebuffer_Protocol&amp;diff=636072&amp;oldid=prev</id>
		<title>imported&gt;Crazy1880: Vorlagen-fix (RFC)</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Remote_Framebuffer_Protocol&amp;diff=636072&amp;oldid=prev"/>
		<updated>2023-05-27T10:30:02Z</updated>

		<summary type="html">&lt;p&gt;Vorlagen-fix (RFC)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{| class=&amp;quot;wikitable float-right&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! colspan=&amp;quot;2&amp;quot; style=&amp;quot;background:#C0C0FF; font-size:larger;&amp;quot;| RFB (Remote Framebuffer Protocol)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Familie:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| [[Internetprotokollfamilie]]&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Einsatzgebiet:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| Datenübertragung,&amp;lt;br /&amp;gt;Bildschirminhalte, Benutzereingaben&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Port:&amp;#039;&amp;#039;&amp;#039; || 5900/TCP (Siehe [[#Port- und Desktopnummern|Text]])&lt;br /&gt;
|-&lt;br /&gt;
|colspan=&amp;quot;2&amp;quot; style=&amp;quot;text-align:center&amp;quot;|&lt;br /&gt;
{{Netzwerk-TCP-IP-Anwendungsprotokoll|RFB|}}&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das &amp;#039;&amp;#039;&amp;#039;Remote Framebuffer Protocol&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;RFB&amp;#039;&amp;#039;&amp;#039;) ist ein [[Netzwerkprotokoll]] für den Zugriff auf die [[Grafische Benutzungsoberfläche|grafischen Benutzungsoberflächen]] (GUI) anderer [[Computer]]. Es wird von [[Virtual Network Computing|VNC]] zur Übertragung von Bildschirminhalten und [[Benutzereingabe]]n verwendet.&lt;br /&gt;
&lt;br /&gt;
== Grundprinzip ==&lt;br /&gt;
Ein RFB-[[Server (Software)|Server]] bietet einen so genannten „Screen“ an. Üblicherweise ist auf diesem ein „[[Desktop (grafische Benutzeroberfläche)|Desktop]]“ oder ein einzelnes Programm einer grafischen Arbeitsumgebung dargestellt, der auf einem entfernten Computer läuft bzw. die dazugehörigen Anwendungen. Der RFB-[[Client]] stellt in der Regel diesen Desktop auf dem Arbeitsplatzrechner des Benutzers dar, nimmt Benutzereingaben ([[Tastatureingabe]]n, [[Mausbewegung]]en und -[[Mausklick|klicks]] usw.) entgegen und leitet diese an den RFB-Server weiter, womit die dortige Arbeitsumgebung gesteuert wird.&lt;br /&gt;
&lt;br /&gt;
Da es auf der Ebene des [[Rastergrafik|bitmaporientierten]] [[Grafikspeicher]]s ({{enS|Framebuffer}}) arbeitet, ist die Anwendung auf beliebigen Fenstersystemen wie [[Windows]], [[Mac&amp;amp;nbsp;OS]] oder [[X11]] möglich. Die Bildschirminhalte werden als Bitmaps übertragen, wobei in der Regel nur die jeweiligen Änderungen –&amp;amp;nbsp;in geeigneter Kodierung, siehe unten&amp;amp;nbsp;– zum Client übertragen werden. Es werden [[Farbtiefe (Computergrafik)|Farbtiefen]] von 8, 16 und 32 Bit pro [[Pixel]] unterstützt, wobei der RFB-Client die gewünschte Farbtiefe und Kodierung vom Server anfordert und der Server sich nach den Wünschen des Clients zu richten hat, sofern er die gewünschte Kodierung unterstützt. Dieses Design erlaubt es, die Anforderungen an den Client einfach zu halten und so die Verwendung von [[Thin Client]]s zu unterstützen.&lt;br /&gt;
&lt;br /&gt;
RFB-Verbindungen sind [[Zustandslosigkeit|zustandslos]], sodass Verbindungsunterbrechungen bzw. der Wechsel des RFB-Clients problemlos möglich sind, ohne dass die zugehörige Sitzung dabei verloren geht. Ziel von RFB und VNC ist letztendlich die Unterstützung des entfernten Arbeitens an Rechnern unter einer einheitlichen Arbeitsumgebung.&lt;br /&gt;
&lt;br /&gt;
=== Port- und Desktopnummern ===&lt;br /&gt;
In der Original-Unix-Version von VNC ist jeder VNC-Server ein eigener [[X-Server]] und stellt genau einen [[X Window System|X-Desktop]] dar ([[Xvnc]]). Es wird dabei standardmäßig die erste freie X-Servernummer von VNC belegt. Falls bereits ein lokaler X-Server auf der Maschine läuft, der somit den X-Desktop &amp;lt;code&amp;gt;:0&amp;lt;/code&amp;gt; belegt, bekommt VNC den Desktop &amp;lt;code&amp;gt;:1&amp;lt;/code&amp;gt;. Die von VNC belegte [[Port (Protokoll)|TCP-Portnummer]] ist &amp;lt;code&amp;gt;5900 + &amp;#039;&amp;#039;desktopnummer&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;, unter Unix somit meist 5901. Einige VNC-Server stellen an Port 5800 bzw. &amp;lt;code&amp;gt;5800 + &amp;#039;&amp;#039;desktopnummer&amp;#039;&amp;#039;&amp;lt;/code&amp;gt; ein [[Java-Applet]] zur Verfügung, mit dem der Desktop mit einem [[Webbrowser]] betrachtet und gesteuert werden kann.&lt;br /&gt;
&lt;br /&gt;
Unter [[Windows]] und [[Mac OS X]] läuft in der Regel &amp;#039;&amp;#039;kein&amp;#039;&amp;#039; lokaler X-Server, so dass VNC den Desktop &amp;lt;code&amp;gt;:0&amp;lt;/code&amp;gt; und somit die TCP-Portnummer 5900 belegt. Dieser Port wird ebenfalls vom Unix-Programm [[x11vnc]] benutzt, welches den bestehenden lokalen X-Server &amp;lt;code&amp;gt;:0&amp;lt;/code&amp;gt; als VNC-Desktop anbietet.&lt;br /&gt;
&lt;br /&gt;
== Protokoll-Details ==&lt;br /&gt;
=== Handshake &amp;amp; Versionskennungen ===&lt;br /&gt;
Sobald die TCP-Verbindung aufgebaut ist, sendet der Server die von ihm unterstützte RFB-Versionsnummer zum Client, worauf dieser mit seiner Protokollversionsnummer antwortet. Die Protokollversion hat den Aufbau &amp;#039;&amp;#039;hauptversion&amp;#039;&amp;#039;&amp;lt;code&amp;gt;.&amp;lt;/code&amp;gt;&amp;#039;&amp;#039;nebenversion&amp;#039;&amp;#039;. Es wird davon ausgegangen, dass die Protokollversionen mit gleicher Hauptversion untereinander kompatibel sind. Die größte von beiden Partnern unterstützte Versionsnummer gilt für die nachfolgende Verbindung als vereinbart. Es steht aber jedem Kommunikationspartner frei, nach dem Austausch der Protokollversionen die Verbindung zu beenden, wenn mit der ausgehandelten Protokollversion nicht kommuniziert werden kann oder soll.&lt;br /&gt;
&lt;br /&gt;
Die Versionskennung ist stets ein 12&amp;amp;nbsp;Byte langer [[American Standard Code for Information Interchange|ASCII]]-String, welcher mit einem [[Zeilenumbruch|LineFeed]]-Zeichen abgeschlossen wird. Die gebräuchlichsten Versionen sind 3.3, 3.7 und 3.8:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|+ RFB Versionskennungen&lt;br /&gt;
!Version!!Kennung!!Kennung (hex)!!Veröffentlicht&lt;br /&gt;
|-&lt;br /&gt;
||3.3 || &amp;lt;code&amp;gt;RFB&amp;amp;nbsp;003.003\n&amp;lt;/code&amp;gt; || &amp;lt;code style=&amp;quot;white-space:nowrap&amp;quot;&amp;gt;52 46 42 20 30 30 33 2E 30 30 33 0A&amp;lt;/code&amp;gt; || Januar 1998 von Olivetti Research Laboratories (ORL)&lt;br /&gt;
|-&lt;br /&gt;
||3.7 || &amp;lt;code&amp;gt;RFB&amp;amp;nbsp;003.007\n&amp;lt;/code&amp;gt; || &amp;lt;code&amp;gt;52 46 42 20 30 30 33 2E 30 30 37 0A&amp;lt;/code&amp;gt; || Juli 2003 von RealVNC Ltd.&lt;br /&gt;
|-&lt;br /&gt;
||3.8 || &amp;lt;code&amp;gt;RFB&amp;amp;nbsp;003.008\n&amp;lt;/code&amp;gt; || &amp;lt;code&amp;gt;52 46 42 20 30 30 33 2E 30 30 38 0A&amp;lt;/code&amp;gt; || Juli 2005 von RealVNC Ltd.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Einige Clients melden fehlerhafterweise eine Protokollversion 3.5. Diese sollte serverseitig wie Version 3.3 behandelt werden.&lt;br /&gt;
&lt;br /&gt;
=== Client-Authentifizierung ===&lt;br /&gt;
Sofern Client und Server eine kompatible RFB-Version ausgehandelt haben, sendet der Server, welche Art von Authentifizierung er vom Client verlangt. In der originalen RFB-Spezifikation sind zwei Arten definiert: „VNC Authentifizierung“ oder „keine Authentifizierung“. Es sind aber weitere Authentifizierungsarten von Drittherstellern definiert worden. Der Client entscheidet, über welche der vom Server angebotenen Authentifizierungsarten er sich am Server authentifizieren will.&lt;br /&gt;
&lt;br /&gt;
=== Initialisierung ===&lt;br /&gt;
Nach erfolgreicher Authentifizierung sendet der Client eine 1&amp;amp;nbsp;Byte große „ClientInit“-Nachricht. Diese enthält lediglich ein Flag, ob der Client eine „shared“ Verbindung akzeptiert, d.&amp;amp;nbsp;h., dass eventuelle Verbindungen des Servers zu anderen Clients erlaubt sind oder (falls das Flag auf 0 ist) beendet werden sollen.&lt;br /&gt;
&lt;br /&gt;
Anschließend sendet der Server eine „ServerInit“-Nachricht. Diese enthält den Namen des Desktops (der oft aus dem Rechnernamen des Servers abgeleitet wird), die Größe des Desktops (in Pixeln) und die native Farbtiefe und Anordnung der Pixel auf Serverseite. Die Bilddaten werden standardmäßig in diesem Format zum Client übertragen, außer der Client fordert über eine „SetPixelFormat“-Nachricht die Daten in einem anderen, für den Client einfacher zu verarbeitenden Format an.&lt;br /&gt;
&lt;br /&gt;
=== Datenübertragung ===&lt;br /&gt;
Der Client steuert, ob und wann Daten übertragen werden sollen. Er sendet die lokalen Tastatur- und Mauseingaben an den Server. Außerdem sendet er regelmäßig „FramebufferUpdateRequest“-Nachrichten an den Server, der daraufhin die &amp;#039;&amp;#039;Änderungen&amp;#039;&amp;#039; des Bildschirminhaltes (seit dem letzten FramebufferUpdateRequest) an den Client sendet.&lt;br /&gt;
&lt;br /&gt;
In der ursprünglichen RFB-Version wurden auch die Bewegungen des Mauszeigers über normale FramebufferUpdates an den Client geschickt. Dabei ist die zu übertragene Datenmenge recht hoch und vor allem die damit verbundenen Latenzen erschweren die Bedienung. Mit RFB-Version 3.8 wurde eine Erweiterung eingeführt, die es erlaubt, dass der Mauszeiger vom Client lokal gezeichnet wird und vom Server lediglich das Aussehen des Mauspfeils und dessen Änderungen (z.&amp;amp;nbsp;B. wenn sich der Mauspfeil über ein Eingabefeld bewegt und dann zum I-Cursor wird) an den Client übertragen werden.&lt;br /&gt;
&lt;br /&gt;
Ebenso kann seit Version 3.8. eine Änderung an der Größe des Desktops an den Client übertragen werden. Bei früheren Versionen musste der Server die Verbindung zum Client beenden, da nur in der Initialisierungsphase einer Verbindung die Größe des Desktops an den Client übertragen werden konnte.&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* {{RFC-Internet |Autor=T. Richardson, J. Levine |RFC=6143 |Titel=The Remote Framebuffer Protocol |Datum=2011-03}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Netzwerkprotokoll auf Anwendungsschicht]]&lt;br /&gt;
[[Kategorie:Remote Access]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Crazy1880</name></author>
	</entry>
</feed>