<?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=Representational_State_Transfer</id>
	<title>Representational State Transfer - 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=Representational_State_Transfer"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Representational_State_Transfer&amp;action=history"/>
	<updated>2026-05-23T18:45:11Z</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=Representational_State_Transfer&amp;diff=449911&amp;oldid=prev</id>
		<title>imported&gt;Invisigoth67: typo</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Representational_State_Transfer&amp;diff=449911&amp;oldid=prev"/>
		<updated>2026-04-08T11:59:00Z</updated>

		<summary type="html">&lt;p&gt;typo&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;Representational State Transfer&amp;#039;&amp;#039;&amp;#039; (abgekürzt &amp;#039;&amp;#039;&amp;#039;REST&amp;#039;&amp;#039;&amp;#039;) ist ein [[Paradigma]] für die [[Softwarearchitektur]] von [[Verteiltes System|verteilten Systemen]], insbesondere für [[Webservice]]s. REST ist eine Abstraktion der Struktur und des Verhaltens des [[World Wide Web]]. REST hat das Ziel, einen Architekturstil zu schaffen, der den Anforderungen des modernen Web besser genügt. Dabei unterscheidet sich REST vor allem in der Forderung nach einer einheitlichen Schnittstelle (siehe Abschnitt [[#Prinzipien|Prinzipien]]) von anderen Architekturstilen.&lt;br /&gt;
&lt;br /&gt;
Der Zweck von REST liegt schwerpunktmäßig auf der [[Maschine-zu-Maschine-Kommunikation]]. REST stellt eine einfache Alternative zu ähnlichen Verfahren wie [[SOAP]] und [[Web Services Description Language|WSDL]] und dem verwandten Verfahren [[Remote Procedure Call|RPC]] dar. Anders als bei vielen verwandten [[Architektur (Informatik)|Architekturen]] kodiert REST keine Methodeninformation in den [[Uniform Resource Identifier|URI]], da ein URI nur den Ort (URL) oder Namen (URN) einer Ressource angibt, nicht aber die Funktionalität, die der Web-Dienst zu der Ressource anbietet. Der Vorteil von REST liegt darin, dass im WWW bereits ein Großteil der für REST nötigen Infrastruktur (z.&amp;amp;nbsp;B. Web- und Application-Server, [[Hypertext Transfer Protocol|HTTP]]-fähige Clients, [[Hypertext Markup Language|HTML]]- und [[Extensible Markup Language|XML]]-Parser, Sicherheitsmechanismen) vorhanden ist und viele Web-Dienste per se REST-konform sind. Eine Ressource kann dabei über verschiedene [[Internet Media Type|Medientypen]] dargestellt werden, auch &amp;#039;&amp;#039;Repräsentation der Ressource&amp;#039;&amp;#039; genannt.&lt;br /&gt;
&lt;br /&gt;
So ist ein [[Online-Dienst]], der lediglich unveränderte Seiteninhalte nach dem Internetstandard HTTP anbietet, bereits REST-konform. Dynamisch erzeugte Seiten folgen diesem Paradigma jedoch oft nicht. So bieten beispielsweise Nachrichtenseiten sich ständig ändernde Informationen mit sowohl unterschiedlichem Format als auch Inhalt an, die nur schwer automatisch verarbeitet werden können. Bliebe das Format unverändert, so wäre eine wichtige REST-Eigenschaft erfüllt. So wäre eine Webseite, auf der ständig die aktuelle Uhrzeit in immer demselben Format abrufbar ist, REST-konform.&lt;br /&gt;
&lt;br /&gt;
Die Bezeichnung „Representational State Transfer“ soll den Übergang vom aktuellen Zustand zum nächsten Zustand (state) einer Applikation verbildlichen. Dieser Zustandsübergang erfolgt durch den Transfer der Daten, die den nächsten Zustand repräsentieren.&amp;lt;ref name=&amp;quot;fielding_experiences&amp;quot;&amp;gt;{{Internetquelle |autor=Roy Fielding |url=https://www.ics.uci.edu/~fielding/pubs/dissertation/evaluation.htm |titel=6: Experience and Evaluation |werk=Architectural Styles and the Design of Network-based Software Architectures |datum=2000 |sprache=en |abruf=2015-06-15}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Geschichte ==&lt;br /&gt;
Das REST-Paradigma entwickelte sich aus dem 1994 von [[Roy Fielding]] entworfenen HTTP Object Model. Fielding entwickelte seine Idee von einem einheitlichen Konzept über die Jahre weiter, bis er 2000 den REST-Architekturstil im Rahmen seiner [[Dissertation]] veröffentlichte.&amp;lt;ref&amp;gt;{{Literatur |Autor=Roy Thomas Fielding |Titel=Architectural Styles and the Design of Network-based Software Architectures – Dissertation |Datum=2000 |Online=[https://www.ics.uci.edu/~fielding/pubs/dissertation/fielding_dissertation_2up.pdf Volltext] |Format=PDF |KBytes=900 |Abruf=2021-01-06}}&amp;lt;/ref&amp;gt; Das [[Programmierparadigma]] der „RESTful Application“ wurde allerdings häufig falsch umgesetzt und findet erst seit 2014 Anklang in der Welt des World Wide Web. In seiner Arbeit geht Fielding dabei auf die verschiedenen Anforderungen ein, die für die Webarchitektur wichtig sind.&lt;br /&gt;
&lt;br /&gt;
== Prinzipien ==&lt;br /&gt;
Der Architekturstil verweist auf sechs Eigenschaften, die ein Dienst haben muss. Dabei ist nicht festgelegt, wie diese Prinzipien implementiert werden müssen. Fielding beschreibt für jedes Architekturprinzip dessen Vor- und Nachteile.&amp;lt;ref&amp;gt;{{Literatur |Autor=Roy Thomas Fielding |Titel=Architectural Styles and the Design of Network-based Software Architectures – Dissertation |Datum=2000 |Seiten=79ff}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Client-Server ===&lt;br /&gt;
Es gilt generell die Anforderung, dass alle Eigenschaften der [[Client-Server-Architektur]] gelten. Dabei stellt der Server einen Dienst bereit, der bei Bedarf vom Client angefragt werden kann. Der Hauptvorteil dieser Anforderung ist die einfache [[Skalierbarkeit]] der Server, da diese unabhängig vom Client agieren. Dies ermöglicht des Weiteren eine unterschiedlich schnelle Entwicklung der beiden Komponenten.&lt;br /&gt;
&lt;br /&gt;
=== Zustandslosigkeit ===&lt;br /&gt;
Jede REST-Nachricht enthält alle Informationen, die für den Server bzw. Client notwendig sind, um die Nachricht zu verstehen. Weder der Server noch die Anwendung soll Zustandsinformationen zwischen zwei Nachrichten speichern. Man spricht daher von einem [[Zustandslosigkeit|zustandslosen]] (englisch: &amp;#039;&amp;#039;stateless&amp;#039;&amp;#039;) Protokoll. Jede Anfrage eines Clients an den Server ist insofern in sich geschlossen, als dass sie sämtliche Informationen über den Anwendungszustand beinhaltet, die vom Server für die Verarbeitung der Anfrage benötigt werden.&lt;br /&gt;
&lt;br /&gt;
Zustandslosigkeit in der hier beschriebenen Form begünstigt die [[Skalierbarkeit]] eines Webservices. Beispielsweise können eingehende Anfragen im Zuge der [[Lastverteilung (Informatik)|Lastverteilung]] unkompliziert auf beliebige Maschinen verteilt werden: Da jede Anfrage in sich geschlossen ist und Anwendungsinformationen somit ausschließlich auf der Seite des Clients vorgehalten werden, ist auf der Seite des Servers keine Sitzungsverwaltung erforderlich. In der Praxis nutzen deswegen viele HTTP-basierte Anwendungen [[HTTP-Cookie|Cookies]] und andere Techniken, um Zustandsinformationen auf der Client-Seite zu behalten. Weiterhin begünstigt wird die Ausfallsicherheit, weil die Zustandslosigkeit fordert, dass transaktionale Datenübertragung in einem einzigen Seitenaufruf erfolgt. Die Zustandslosigkeit bringt dabei aber den Nachteil mit, dass sich die Netzwerkperformance verschlechtert. Da bei jeder Abfrage alle Informationen zum Verstehen mitgeschickt werden müssen, sind aufwendigere Abfragen nötig, als wenn sich der Server die Interaktionen merken würde.&lt;br /&gt;
&lt;br /&gt;
=== Caching ===&lt;br /&gt;
[[HTTP Caching]] soll genutzt werden, wobei gilt: Eine Anfrage, die nicht gestellt werden muss, ist die schnellste Anfrage. Fielding führt dabei den Nachteil auf, dass der Client auf veraltete Cache-Daten zurückgreifen könnte, statt die neue Ressource abzufragen.&lt;br /&gt;
&lt;br /&gt;
=== Einheitliche Schnittstelle ===&lt;br /&gt;
Dies ist das Hauptunterscheidungsmerkmal von allen weiteren Architekturstilen. Dabei besteht diese aus vier weiteren Eigenschaften. Ziel ist die Einheitlichkeit der Schnittstelle und somit ihre einfache Nutzung.&lt;br /&gt;
&lt;br /&gt;
==== Adressierbarkeit von Ressourcen ====&lt;br /&gt;
Jede Information, die über einen URI kenntlich gemacht wurde, wird als Ressource gekennzeichnet. Jeder REST-konforme Dienst hat eine eindeutige Adresse, den [[Uniform Resource Locator]] (URL). Diese „Straße und Hausnummer im Netz“ standardisiert den Zugriffsweg zum Angebot eines Webservices für eine Vielzahl von Anwendungen (Clients). Eine konsistente Adressierbarkeit erleichtert es außerdem, einen Webservice als Teil eines [[Mashup (Internet)|Mashups]] weiterzuverwenden.&lt;br /&gt;
&lt;br /&gt;
==== Repräsentationen zur Veränderung von Ressourcen ====&lt;br /&gt;
Die unter einer Adresse zugänglichen Dienste können unterschiedliche Darstellungsformen (Repräsentationen) haben. Ein REST-konformer Server kann, je nachdem, was die Anwendung anfordert, verschiedene Repräsentationen einer Ressource ausliefern, z.&amp;amp;nbsp;B. in verschiedenen Sprachen oder Formaten ([[Hypertext Markup Language|HTML]], [[JavaScript Object Notation|JSON]] oder [[Extensible Markup Language|XML]]) oder auch die Beschreibung oder Dokumentation des Dienstes. Diese Repräsentation enthält alle nötigen Informationen zur Veränderung der Ressource und muss nicht der intern vom Server verwendeten Repräsentation entsprechen (z.&amp;amp;nbsp;B. die Repräsentation zwischen Client und Server wird als JSON ausgetauscht, intern speichert der Server die Informationen aber in verschiedenen Spalten einer [[Relationale Datenbank|relationalen Datenbank]] ab).&lt;br /&gt;
Die Veränderung einer Ressource (also deren aktuellen Status) soll nur über eine Repräsentation erfolgen.&lt;br /&gt;
&lt;br /&gt;
==== Selbstbeschreibende Nachrichten ====&lt;br /&gt;
REST-Nachrichten sollen selbstbeschreibend sein. Dazu zählt u.&amp;amp;nbsp;a. die Verwendung von Standardmethoden. Über diese Standardmethoden lassen sich Ressourcen manipulieren. Als Beispiel seien an dieser Stelle die HTTP-Verben genannt; Details siehe unten.&lt;br /&gt;
&lt;br /&gt;
==== „Hypermedia as the Engine of Application State“ (HATEOAS) ====&lt;br /&gt;
Dies ist laut Fielding die wichtigste Eigenschaft; siehe [[#HATEOAS|unten]].&lt;br /&gt;
&lt;br /&gt;
=== Mehrschichtige Systeme ===&lt;br /&gt;
Die Systeme sollen mehrschichtig aufgebaut sein. Dadurch reicht es, dem Anwender lediglich eine Schnittstelle anzubieten. Dahinterliegende Ebenen können verborgen bleiben und somit die Architektur insgesamt vereinfacht werden. Vorteile dabei sind die bessere Skalierbarkeit der Server sowie eine mögliche Abkapselung durch Firewalls. Durch Cache-Speicher an den Grenzen (z.&amp;amp;nbsp;B. vom Server zum Web) kann die Effizienz der Anfragen erhöht werden; siehe Caching.&lt;br /&gt;
&lt;br /&gt;
=== Code on Demand (optional) ===&lt;br /&gt;
Diese Forderung von Fielding ist optional. Unter Code on Demand ist zu verstehen, dass erst im Bedarfsfall an den Client Code zur lokalen Ausführung übertragen werden kann.&amp;lt;br /&amp;gt;&lt;br /&gt;
Ein Beispiel hierfür wäre die Übertragung von JavaScript-Code bei einer HTML-Repräsentation.&lt;br /&gt;
&lt;br /&gt;
== Umsetzung ==&lt;br /&gt;
Für die Umsetzung des REST-Paradigmas wird ein zustandsloses Client-Server-Protokoll verwendet. Als Anwendungsschicht-Protokolle werden hauptsächlich [[Hypertext Transfer Protocol|HTTP]] und [[Hypertext Transfer Protocol Secure|HTTPS]] eingesetzt. Das liegt unter anderem daran, dass sich diese im WWW etabliert haben, über einen vergleichsweise einfachen Aufbau verfügen und mit so gut wie jeder [[Firewall]] kompatibel sind. REST vereinheitlicht die Schnittstelle zwischen Systemen auf eine überschaubare und bezüglich des zu erwartenden Verhaltens standardisierte Menge von Aktionen. Welche Aktionen dies sind, ist in REST nicht festgelegt, aber alle Aktionen sind allgemein definiert, in der Regel durch die verwendeten Protokolle der Anwendungsschicht.&lt;br /&gt;
&lt;br /&gt;
Während REST als Abstraktion des WWW keine spezielle [[Implementierung]] und kein spezielles Protokoll fordert, ist doch zu beobachten, dass fast ausschließlich HTTP verwendet wird, wodurch auch die Menge der Aktionen festgelegt ist.&lt;br /&gt;
&lt;br /&gt;
Wird über HTTP zugegriffen, so gibt die verwendete HTTP-Methode, darunter &amp;lt;code&amp;gt;GET&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;POST&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;PUT&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;DELETE&amp;lt;/code&amp;gt;, an, welche Operation des Dienstes gewünscht ist.&lt;br /&gt;
HTTP schreibt vor, dass &amp;lt;code&amp;gt;GET&amp;lt;/code&amp;gt; „sicher“ ({{enS|safe}}) sein muss, was bedeutet, dass diese Methode nur Informationen beschafft und keine sonstigen Effekte verursacht. Die Methoden &amp;lt;code&amp;gt;GET&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;HEAD&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;PUT&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;DELETE&amp;lt;/code&amp;gt; müssen laut HTTP-Spezifikation [[Idempotenz|idempotent]] sein, was in diesem Zusammenhang bedeutet, dass das mehrfache Absenden der gleichen Anforderung sich nicht anders auswirkt als ein einzelner Aufruf.&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=2616 |Titel=Hypertext Transfer Protocol – HTTP/1.1 |Datum=1999-06 |Autor=Fielding et al. |Abschnitt=9 |Abschnittstitel=Method Definitions}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
REST-Clients, die HTTP verwenden, können folgende Befehle absetzen, um Ressourcen anzufordern oder zu verändern:&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Befehl&amp;lt;br /&amp;gt; (HTTP-Methode) !! Beschreibung !! Anmerkungen&lt;br /&gt;
|-&lt;br /&gt;
| GET&lt;br /&gt;
| Fordert die angegebene Ressource vom Server an. GET weist keine Nebeneffekte auf. Der Zustand am Server wird nicht verändert, weshalb GET als &amp;#039;&amp;#039;sicher&amp;#039;&amp;#039; bezeichnet wird.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| POST&lt;br /&gt;
| Fügt eine neue (Sub-)Ressource unterhalb der angegebenen Ressource ein. Da die neue Ressource noch keinen URI besitzt, adressiert der URI die übergeordnete Ressource. Als Ergebnis wird der neue Ressourcenlink dem Client zurückgegeben. POST kann im weiteren Sinne auch dazu verwendet werden, Operationen abzubilden, die von keiner anderen Methode abgedeckt werden.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nicht-idempotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| PUT&lt;br /&gt;
| Die angegebene Ressource wird angelegt. Wenn die Ressource bereits existiert, wird sie geändert.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;idempotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| PATCH&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;patch&amp;quot; /&amp;gt;&lt;br /&gt;
| Ein Teil der angegebenen Ressource wird geändert. Hierbei sind Nebeneffekte erlaubt.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| DELETE&lt;br /&gt;
| Löscht die angegebene Ressource.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;idempotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| HEAD&lt;br /&gt;
| Fordert Metadaten zu einer Ressource an.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| OPTIONS&lt;br /&gt;
| Prüft, welche Methoden auf einer Ressource zur Verfügung stehen.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| CONNECT&lt;br /&gt;
| Dient dazu, die Anfrage durch einen TCP-Tunnel zu leiten. Wird meist eingesetzt, um eine HTTPS-Verbindung über einen HTTP-Proxy herzustellen.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;sicherheit&amp;quot; /&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| TRACE&lt;br /&gt;
| Gibt die Anfrage zurück, wie sie der Zielserver erhält. Dient etwa dazu, um Änderungen der Anfrage durch Proxyserver zu ermitteln.&lt;br /&gt;
|&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot; /&amp;gt;&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;sicherheit&amp;quot; /&amp;gt;&lt;br /&gt;
|- class=&amp;quot;sortbottom&amp;quot;&lt;br /&gt;
|colspan=&amp;quot;3&amp;quot;|&lt;br /&gt;
&amp;lt;references group=&amp;quot;n&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;optional&amp;quot;&amp;gt;&lt;br /&gt;
optional. Wird nicht für [[CRUD]]-Operationen benötigt.&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nullipotent&amp;quot;&amp;gt;&lt;br /&gt;
[[nullipotent]]. Ein Aufruf dieser Methoden führt zu keinen Nebeneffekten.&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;idempotent&amp;quot;&amp;gt;&lt;br /&gt;
[[Idempotenz|idempotent]]. Der erste Aufruf dieser Methoden mit einem bestimmten URI führt zu Nebeneffekten. Ein erneuter Aufruf mit demselben URI führt zu keinen weiteren Nebeneffekten.&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;nicht-idempotent&amp;quot;&amp;gt;&lt;br /&gt;
nicht idempotent. Ein erneuter Aufruf erstellt für jeden Aufruf mit demselben URI ein neues Objekt, anstatt dasselbe Objekt zurückzugeben.&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref group=&amp;quot;n&amp;quot; name=&amp;quot;sicherheit&amp;quot;&amp;gt;&lt;br /&gt;
Eine Implementierung dieser Methoden wirkt sich ggf. auf die Sicherheit der Anwendung aus.&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;patch&amp;quot;&amp;gt;&lt;br /&gt;
{{RFC-Internet |RFC=5789 |Titel=PATCH Method for HTTP |Datum=2010-03}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Abhängig von der Implementierung können noch weitere HTTP-Befehle unterstützt werden. Dazu gehören &amp;lt;code&amp;gt;COPY&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;MOVE&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;MKCOL&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;LOCK&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;UNLOCK&amp;lt;/code&amp;gt; des [[WebDAV]]-Protokolls&amp;lt;ref name=&amp;quot;WebDAVMethods&amp;quot;&amp;gt;{{Internetquelle |url=https://msdn.microsoft.com/en-us/library/aa142917.aspx?f=255&amp;amp;MSPPError=-2147217396 |titel=WebDAV Methods |werk=[[Microsoft Developer Network|MSDN]] |datum=2007-06 |sprache=en |abruf=2016-02-13}}&amp;lt;/ref&amp;gt;, sowie &amp;lt;code&amp;gt;LINK&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;UNLINK&amp;lt;/code&amp;gt; aus &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;2068&amp;lt;/nowiki&amp;gt;.&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=2068 |Titel=Hypertext Transfer Protocol – HTTP/1.1 |Datum=1997-01 |Autor=Fielding et al.}}&amp;lt;/ref&amp;gt; Bei der Kommunikation über UDP kann zudem das [[Constrained Application Protocol|CoAP]] aus &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;7252&amp;lt;/nowiki&amp;gt;&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=7252 |Titel=The Constrained Application Protocol (CoAP) |Datum=2014-06}}&amp;lt;/ref&amp;gt; statt HTTP eingesetzt werden, welches leicht abweichende Bedeutungen für &amp;lt;code&amp;gt;GET&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;POST&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;PUT&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;DELETE&amp;lt;/code&amp;gt; besitzt.&lt;br /&gt;
&lt;br /&gt;
== Sicherheit ==&lt;br /&gt;
Das Paradigma verlangt, dass &amp;#039;&amp;#039;alle&amp;#039;&amp;#039; Informationen, die eine Anwendung braucht, um den Seitenzustand wiederherzustellen, in der Anfrage enthalten sind. Dabei identifiziert der URI die Ressource, während im HTTP-Header Informationen wie Zugriffsart (GET, PUT), Rückgabeformat oder Authentifizierung enthalten sein können.&lt;br /&gt;
&lt;br /&gt;
REST lässt sich für Webseiten und Webservices verwenden, die keine Authentifizierung erfordern oder diese auf anderem Wege (beispielsweise durch Prüfung der [[IP-Adresse]], durch [[HTTP-Authentifizierung]] oder [[Transport Layer Security|TLS]]/[[Hypertext Transfer Protocol Secure|HTTPS]]-Zertifikatsprüfung) erreichen, wodurch bereits viele Anwendungsfälle abgedeckt werden können. Alternativ können auch [[Token (Rechnernetz)|Token]]-basierte Verfahren wie [[Keyed-Hash Message Authentication Code|HMAC]], [[OAuth]], [[JSON Web Token]] oder [[OpenID]] verwendet werden.&lt;br /&gt;
&lt;br /&gt;
Da REST –&amp;amp;nbsp;im Gegensatz zu SOAP mit [[WS-Security]]&amp;amp;nbsp;– selbst keine Verschlüsselungsmethoden definiert, wird bei sicherheitskritischen Nachrichten ein verschlüsseltes Transportprotokoll wie [[Hypertext Transfer Protocol Secure|HTTPS]] verwendet.&lt;br /&gt;
&lt;br /&gt;
Durch die Nutzung der HTTP-Methoden ist es für Firewalls möglich, die Anfrage zu verstehen, zu filtern und zu protokollieren. Ein Beispiel dafür wäre, dass alle PUT-Anfragen von einer externen Ressource abgelehnt werden können. Dadurch unterscheidet sich REST von beispielsweise [[SOAP]].&lt;br /&gt;
&lt;br /&gt;
== Versionierung ==&lt;br /&gt;
Um einen REST-Service zu versionieren, stehen mehrere Varianten zur Auswahl: über die DNS-Adresse, URL und mittels HTTP-Header.&lt;br /&gt;
&lt;br /&gt;
Bei der &amp;#039;&amp;#039;&amp;#039;DNS-Versionierung&amp;#039;&amp;#039;&amp;#039; wird die Version als Bestandteil des Hostnamens behandelt.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://v1.api.example.com/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://v1_1.api.example.com/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://v2.api.example.com/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://v2_2.api.example.com/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Diese Variante ist, wegen der Verwaltung im DNS, üblicherweise mit hohem Aufwand verbunden. In der Praxis ist sie daher kaum anzutreffen.&lt;br /&gt;
&lt;br /&gt;
Bei der &amp;#039;&amp;#039;&amp;#039;URL-Versionierung&amp;#039;&amp;#039;&amp;#039; wird die Version der Schnittstelle im Pfad der URL angegeben:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://example.com/api/v1/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://example.com/api/v1.1/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://example.com/api/v2.0/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://example.com/api/v2.2/customer/1234&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Die Versionierung über die URL ist die gebräuchlichste Variante.&lt;br /&gt;
&lt;br /&gt;
Bei der Versionierung über den &amp;#039;&amp;#039;&amp;#039;HTTP-Header&amp;#039;&amp;#039;&amp;#039; wird die Version im Accept-HTTP-Header angegeben:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot; highlight=&amp;quot;3&amp;quot;&amp;gt;&lt;br /&gt;
GET /api/customer/1234 HTTP/1.1&lt;br /&gt;
Host: example.com&lt;br /&gt;
Accept: application/xml,application/json;version=1&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Nach der Bereitstellung einer neuen Version des Services muss die alte Version des Endpunktes für eine bestimmte Zeit weiter bereitgestellt werden, um dem Nutzer Zeit zur Umstellung zu geben. Eine Clientanwendung sollte automatisch erkennen können, dass der Endpunkt obsolet ist, ohne den Endpunkt in der Nutzung einzuschränken. Dies kann mittels eines Warning-HTTP-Headers&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=7234 |Titel=Hypertext Transfer Protocol (HTTP/1.1): Caching |Datum=2014-06 |Abschnitt=5.5 |Abschnittstitel=Warning}}&amp;lt;/ref&amp;gt; erfolgen:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot; highlight=&amp;quot;4&amp;quot;&amp;gt;&lt;br /&gt;
HTTP/1.1 200 OK&lt;br /&gt;
Date: Sat, 11 Mar 2017 12:28:53 GMT&lt;br /&gt;
Server: Apache/2.2.14 (Win32)&lt;br /&gt;
Warning: 299 example.com/api/v1 &amp;quot;Deprecated API : use example.com/api/v1.1 instead. Old API maintained until 2017-06-02&amp;quot;&lt;br /&gt;
Content-Length: 88&lt;br /&gt;
Content-Type: application/json&lt;br /&gt;
Connection: Closed&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Der Client sollte die Warnung im [[Logdatei|Log]] und in einer [[Operations-Datenbank|OpsDB]] protokollieren, um es dem Betreiber des Clienten zu ermöglichen, rechtzeitig auf die neue API umzustellen.&lt;br /&gt;
&lt;br /&gt;
Wird der alte Endpunkt weiter angeboten, sollte der neue Endpunkt mittels eines HTTP-Redirects unter der alten Adresse auffindbar sein:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot; highlight=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
GET /api/v1/customer/1234 HTTP/1.1&lt;br /&gt;
Host: example.com&lt;br /&gt;
Accept: application/xml,application/json&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot; highlight=&amp;quot;2&amp;quot;&amp;gt;&lt;br /&gt;
HTTP/1.1 302 Found&lt;br /&gt;
Location: example.com/api/v1.1/customer/1234&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Grundsätzlich ist es empfehlenswert, vor dem Auflassen eines obsoleten Endpunktes mittels [[Monitoring]] zu prüfen, ob dieser Endpunkt noch aktiv verwendet wird. Zudem sollte mittels [[Operations-Datenbank|OpsDB]] geprüft werden, ob es sich um einen Endpunkt handelt, der nur selten (z.&amp;amp;nbsp;B. quartalsweise) verwendet wird.&lt;br /&gt;
&lt;br /&gt;
== HATEOAS ==&lt;br /&gt;
{{Hauptartikel|HATEOAS}}&lt;br /&gt;
HATEOAS steht für &amp;#039;&amp;#039;Hypermedia as the Engine of Application State&amp;#039;&amp;#039; und ist ein Entwurfsprinzip von REST-Architekturen. Bei HATEOAS navigiert der Client einer REST-Schnittstelle ausschließlich über URLs, die vom Server bereitgestellt werden.&amp;lt;ref&amp;gt;{{Internetquelle |autor=Andreas Würl, Jörg Adler |url=https://www.heise.de/developer/artikel/Hoechster-Reifegrad-fuer-REST-mit-HATEOAS-3550392.html |titel=Höchster Reifegrad für REST mit HATEOAS |hrsg=[[Verlag Heinz Heise|Heise]] |datum=2016-12-06 |abruf=2021-01-06}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Abhängig von der gewählten Repräsentation geschieht die Bereitstellung der URIs über [[Hypermedia]], also z.&amp;amp;nbsp;B.&lt;br /&gt;
* in Form von „href“- und „src“-Attributen bei [[Hypertext Markup Language|HTML]]-Dokumenten bzw. HTML-Snippets, oder&lt;br /&gt;
* in für die jeweilige Schnittstelle definierten und dokumentierten JSON- bzw. XML-Attributen/-Elementen.&lt;br /&gt;
&lt;br /&gt;
Abstrakt betrachtet stellen HATEOAS-konforme REST-Services einen [[Endlicher Automat|endlichen Automaten]] dar, dessen Zustandsveränderungen durch die Navigation mittels der bereitgestellten URIs erfolgt.&lt;br /&gt;
&lt;br /&gt;
Durch HATEOAS ist eine lose Bindung gewährleistet und die Schnittstelle kann verändert werden. Im Gegensatz dazu kommuniziert ein SOAP-basierter Webservice über ein fixiertes Interface. Für eine Änderung des Service muss hier eine neue Schnittstelle bereitgestellt werden und in der [[Schnittstellenbeschreibungssprache|Schnittstellenbeschreibung]] (ein [[Web Services Description Language|WSDL]]-Dokument) definiert werden. Registrierungsdatenbanken oder ähnliche Infrastrukturen, die z.&amp;amp;nbsp;B. bei [[Remote Function Call]] erforderlich sind, werden bei HATEOAS nicht benötigt.&lt;br /&gt;
&lt;br /&gt;
Zur Abbildung von HATEOAS gibt es unterschiedliche Standards. Hierzu gehören:&amp;lt;ref&amp;gt;{{Internetquelle |autor=Kevin Sookocheff |url=https://sookocheff.com/post/api/on-choosing-a-hypermedia-format/ |titel=On choosing a hypermedia type for your API – HAL, JSON-LD, Collection+JSON, SIREN, Oh My! |datum=2014-03-11 |sprache=en |abruf=2017-06-11}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
* [http://jsonapi.org/ JSON API]&lt;br /&gt;
* [[JSON-LD]] und [http://www.markus-lanthaler.com/hydra/ Hydra]&lt;br /&gt;
* [http://amundsen.com/media-types/collection/ Collection+JSON]&lt;br /&gt;
* [https://github.com/kevinswiber/siren Siren]&lt;br /&gt;
&lt;br /&gt;
=== Beispiel ===&lt;br /&gt;
Im Beispiel sieht man einen GET-Request, der Konto-Informationen im JSON-Format abruft:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;http&amp;quot;&amp;gt;&lt;br /&gt;
GET /accounts/123abc HTTP/1.1&lt;br /&gt;
Host: bank.example.com&lt;br /&gt;
Accept: application/json&lt;br /&gt;
...&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Die Antwort bei einem ausgeglichenen Konto kann dann wie folgt lauten:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;http&amp;quot;&amp;gt;&lt;br /&gt;
HTTP/1.1 200 OK&lt;br /&gt;
Content-Type: application/json&lt;br /&gt;
Content-Length: ...&lt;br /&gt;
&lt;br /&gt;
{&lt;br /&gt;
   &amp;quot;account&amp;quot;: {&lt;br /&gt;
      &amp;quot;account_id&amp;quot;: &amp;quot;123abc&amp;quot;,&lt;br /&gt;
       &amp;quot;balance&amp;quot;: {&lt;br /&gt;
          &amp;quot;currency&amp;quot;: &amp;quot;EUR&amp;quot;,&lt;br /&gt;
          &amp;quot;value&amp;quot;: 100.0&lt;br /&gt;
       },&lt;br /&gt;
       &amp;quot;links&amp;quot;: {&lt;br /&gt;
          &amp;quot;deposit&amp;quot;: &amp;quot;/accounts/123abc/deposit&amp;quot;,&lt;br /&gt;
          &amp;quot;withdraw&amp;quot;: &amp;quot;/accounts/123abc/withdraw&amp;quot;,&lt;br /&gt;
          &amp;quot;transfer&amp;quot;: &amp;quot;/accounts/123abc/transfer&amp;quot;,&lt;br /&gt;
          &amp;quot;close&amp;quot;: &amp;quot;/accounts/123abc/close&amp;quot;&lt;br /&gt;
       }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Beispielantwort 1&lt;br /&gt;
&lt;br /&gt;
Die &amp;#039;&amp;#039;Beispielantwort 1&amp;#039;&amp;#039;  beinhaltet vier mögliche Links: &amp;lt;code&amp;gt;deposit&amp;lt;/code&amp;gt; (einzahlen), &amp;lt;code&amp;gt;withdraw&amp;lt;/code&amp;gt; (abbuchen), &amp;lt;code&amp;gt;transfer&amp;lt;/code&amp;gt; (überweisen) und &amp;lt;code&amp;gt;close&amp;lt;/code&amp;gt; (kündigen). Wenn das Konto überzogen ist, kann nur noch Geld auf das Konto eingezahlt werden, aber keines mehr abgebucht oder überwiesen werden, und man kann das Konto nicht mehr kündigen. Die Antwort bei einem überzogenen Konto kann daher so aussehen:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;http&amp;quot;&amp;gt;&lt;br /&gt;
HTTP/1.1 200 OK&lt;br /&gt;
Content-Type: application/json&lt;br /&gt;
Content-Length: ...&lt;br /&gt;
&lt;br /&gt;
{&lt;br /&gt;
   &amp;quot;account&amp;quot;: {&lt;br /&gt;
      &amp;quot;account_id&amp;quot;: &amp;quot;123abc&amp;quot;,&lt;br /&gt;
       &amp;quot;balance&amp;quot;: {&lt;br /&gt;
           &amp;quot;currency&amp;quot;: &amp;quot;EUR&amp;quot;,&lt;br /&gt;
           &amp;quot;value&amp;quot;: -100.0&lt;br /&gt;
       },&lt;br /&gt;
       &amp;quot;links&amp;quot;: {&lt;br /&gt;
          &amp;quot;deposit&amp;quot;: &amp;quot;/accounts/123abc/deposit&amp;quot;&lt;br /&gt;
       }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Beispielantwort 2&lt;br /&gt;
&lt;br /&gt;
== Richardson Maturity Model ==&lt;br /&gt;
Das Richardson Maturity Model (RMM, deutsch &amp;#039;&amp;#039;Richardson-Reifegradmodell&amp;#039;&amp;#039;) ist ein von Leonard Richardson entwickelter Maßstab, der angibt, wie strikt ein Service REST implementiert. Ein höheres Level entspricht in diesem Model einem höheren Reifegrad.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|+ Richardson Maturity Model&amp;lt;ref name=&amp;quot;RMM&amp;quot;&amp;gt;{{Internetquelle |autor=[[Martin Fowler]] |url=http://martinfowler.com/articles/richardsonMaturityModel.html |titel=Richardson Maturity Model |datum=2010-03-18 |sprache=en |abruf=2013-04-07 |kommentar=Erklärung des REST Maturity Models (RMM)}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
! Level !! Eigenschaften&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;text-align:center&amp;quot;| 0 ||&lt;br /&gt;
* verwendet [[XML-RPC]] oder [[SOAP]]&lt;br /&gt;
* der Service wird über einen einzelnen URI adressiert&lt;br /&gt;
* verwendet eine einzelne HTTP-Methode (oft POST)&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;text-align:center&amp;quot;| 1 ||&lt;br /&gt;
* verwendet verschiedene URIs und Ressourcen&lt;br /&gt;
* verwendet eine einzelne HTTP-Methode (oft POST)&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;text-align:center&amp;quot;| 2 ||&lt;br /&gt;
* verwendet verschiedene URIs und Ressourcen&lt;br /&gt;
* verwendet mehrere HTTP-Methoden&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;text-align:center&amp;quot;| 3 ||&lt;br /&gt;
* basiert auf HATEOAS und verwendet daher [[Hypermedia]] für Navigation&lt;br /&gt;
* verwendet verschiedene URIs und Ressourcen&lt;br /&gt;
* verwendet mehrere HTTP-Methoden&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Abgrenzung zu anderen Kommunikationsmechanismen ==&lt;br /&gt;
Bei REST handelt es sich um ein Programmierparadigma, welches mit verschiedenen Mechanismen implementiert werden kann. Eine Neuerung ist dabei die Verwendung möglichst vieler [[Hypertext Transfer Protocol|HTTP]]-Methoden in Verbindung mit der auszuführenden Aktion. Im Gegensatz dazu wird zum Beispiel SOAP im Wesentlichen mit der POST-Methode verwendet. Der Unterschied liegt also mehr in der breiteren Verwendung von HTTP als Protokoll und URI als Identifizierungsmechanismus für konkrete Objekte. In der Vergangenheit wurden im Gegensatz dazu SOAP-Schnittstellen [[Remote Procedure Call|RPC]]-basiert aufgebaut. Zu den Schwächen von SOAP gehören dabei der recht große Overhead mit vielen Meta- und wenig Nutzdaten sowie das rechenintensive Bauen der XML-Nachrichten. Darüber hinaus gibt es mittlerweile zahlreiche schwer zu überblickende Substandards.&amp;lt;ref&amp;gt;{{Internetquelle |autor=Martin Helmich |url=https://www.mittwald.de/blog/webentwicklung-design/webentwicklung/restful-webservices-1-was-ist-das-uberhaupt |titel=RESTful Webservices (1): Was ist das überhaupt? |datum=2013-03-12 |abruf=2017-11-16}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
Die engen Vorgaben von REST helfen dagegen, gut strukturierte Dienste zu bauen, und unterstützen die Verwendung von [[Clean URL]]s.&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Java API for RESTful Web Services]] (JAX-RS)&lt;br /&gt;
* [[Web Application Description Language]] – Beschreibungssprache für REST-basierte Dienste&lt;br /&gt;
* [[JSON-RPC]] – JSON basiertes RPC-Protokoll&lt;br /&gt;
* [[Open Data Protocol]] (OData)&lt;br /&gt;
* [[OpenAPI]] – Spezifikation zur Beschreibung von REST-Schnittstellen&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* {{Literatur&lt;br /&gt;
   |Autor=Leonard Richardson, Sam Ruby&lt;br /&gt;
   |Titel=Web Services mit REST&lt;br /&gt;
   |Verlag=O’Reilly Verlag&lt;br /&gt;
   |Datum=2007&lt;br /&gt;
   |ISBN=978-3-89721-727-0}}&lt;br /&gt;
* {{Literatur&lt;br /&gt;
   |Autor=Stefan Tilkov et al.&lt;br /&gt;
   |Titel=REST und HTTP&lt;br /&gt;
   |TitelErg=Entwicklung und Integration nach dem Architekturstil des Web&lt;br /&gt;
   |Auflage=3., aktualisierte und erweiterte Auflage&lt;br /&gt;
   |Verlag=dpunkt Verlag&lt;br /&gt;
   |Datum=2015&lt;br /&gt;
   |ISBN=978-3-86490-120-1}}&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* {{Internetquelle |autor=Roy Thomas Fielding |url=http://www.ics.uci.edu/~fielding/pubs/dissertation/top.htm |titel=Architectural Styles and the Design of Network-based Software Architectures |sprache=en |abruf=2013-04-06 |kommentar=Dissertation, in der REST beschrieben wird}}&lt;br /&gt;
* {{Internetquelle |autor=Roy Thomas Fielding |url=http://roy.gbiv.com/untangled/2008/rest-apis-must-be-hypertext-driven |titel=REST APIs must be hypertext-driven |datum=2008-09-20 |sprache=en |abruf=2013-04-07 |kommentar=Empfehlungen zum Entwerfen von REST-Schnittstellen mit HATEOAS}}&lt;br /&gt;
* {{Internetquelle |autor=David Megginson |url=http://quoderat.megginson.com/2007/02/15/rest-the-quick-pitch |titel=The quick pitch |werk=Quoderat |datum=2007-02-15 |sprache=en |abruf=2013-04-06 |kommentar=Pragmatische Empfehlungen für die Anwendung von REST}}&lt;br /&gt;
* {{Internetquelle |autor=Thomas Bayer |url=http://www.oio.de/public/xml/rest-webservices.htm |titel=REST Web Services |hrsg=Orientation in Objects |datum=2002-11 |sprache=de |abruf=2013-04-06 |kommentar=Einführung in RESTful Web Services}}&lt;br /&gt;
* {{Internetquelle |autor=Alex Rodriguez |url=http://www.ibm.com/developerworks/webservices/library/ws-restful/ |titel=RESTful Web services: The basics |werk=developerWorks |hrsg=[[IBM]] |datum=2008-11-06 |sprache=en |abruf=2013-04-06 |kommentar=Basisprinzipien von REST}}&lt;br /&gt;
* {{Internetquelle |autor=Stefan Tilkov |url=http://jaxenter.de/artikel/REST-bessere-Web-Service-167838 |titel=REST – Der bessere Web Service? |werk=jaxenter |hrsg=IT-Republik |datum=2009-02 |sprache=de |abruf=2013-04-06 |kommentar=Grundlagen der REST-Architektur}}&lt;br /&gt;
* {{Internetquelle |autor=Gregor Roth |url=http://www.infoq.com/articles/designing-restful-http-apps-roth |titel=RESTful HTTP in practice |hrsg=InfoQ |datum=2009-08-18 |sprache=en |abruf=2013-04-06 |kommentar=REST in der Praxis}}&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
{{Navigationsleiste Webserver-Schnittstellen}}&lt;br /&gt;
&lt;br /&gt;
{{Normdaten|TYP=s|GND=7592728-7}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Softwarearchitektur]]&lt;br /&gt;
[[Kategorie:Webservice]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Invisigoth67</name></author>
	</entry>
</feed>