<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>URI Archive - CEOsBay</title>
	<atom:link href="https://ceosbay.com/tag/uri/feed/" rel="self" type="application/rss+xml" />
	<link>https://ceosbay.com/tag/uri/</link>
	<description>It&#039;s all about Tech</description>
	<lastBuildDate>Fri, 21 Feb 2025 10:57:14 +0000</lastBuildDate>
	<language>de</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>

<image>
	<url>https://i0.wp.com/ceosbay.com/wp-content/uploads/2022/11/image.jpg?fit=32%2C32&#038;ssl=1</url>
	<title>URI Archive - CEOsBay</title>
	<link>https://ceosbay.com/tag/uri/</link>
	<width>32</width>
	<height>32</height>
</image> 
<site xmlns="com-wordpress:feed-additions:1">211828771</site>	<item>
		<title>RDF (Resource Description Framework)</title>
		<link>https://ceosbay.com/2025/02/21/rdf-resource-description-framework/</link>
					<comments>https://ceosbay.com/2025/02/21/rdf-resource-description-framework/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Fri, 21 Feb 2025 11:30:00 +0000</pubDate>
				<category><![CDATA[Datenwissenschaft]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[Datenintegration]]></category>
		<category><![CDATA[Datenmodellierung]]></category>
		<category><![CDATA[Datenrepräsentation]]></category>
		<category><![CDATA[Datenvernetzung]]></category>
		<category><![CDATA[Interoperabilität]]></category>
		<category><![CDATA[JSON-LD]]></category>
		<category><![CDATA[Linked Data]]></category>
		<category><![CDATA[Maschinenlesbarkeit]]></category>
		<category><![CDATA[Metadaten]]></category>
		<category><![CDATA[Ontologie-Modelle]]></category>
		<category><![CDATA[Ontologien]]></category>
		<category><![CDATA[OWL]]></category>
		<category><![CDATA[rdf]]></category>
		<category><![CDATA[Semantic Web]]></category>
		<category><![CDATA[SPARQL]]></category>
		<category><![CDATA[Triple Store]]></category>
		<category><![CDATA[Turtle]]></category>
		<category><![CDATA[URI]]></category>
		<category><![CDATA[Wissensgraphen]]></category>
		<category><![CDATA[Wissensmanagement]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=4761</guid>

					<description><![CDATA[<p>Das Resource Description Framework (RDF) ist ein Modell zur Repräsentation von Informationen im Web. Es wurde vom World Wide Web Consortium (W3C) entwickelt und ist ein Kernbestandteil des Semantic Web. Es ermöglicht, Daten zu beschreiben, &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2025/02/21/rdf-resource-description-framework/">RDF (Resource Description Framework)</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">Das <strong>Resource Description Framework (RDF)</strong> ist ein Modell zur Repräsentation von Informationen im Web. Es wurde vom <strong><a href="https://www.w3.org">World Wide Web Consortium</a> (<a href="https://www.w3.org">W3C</a>)</strong> entwickelt und ist ein Kernbestandteil des <strong><strong>Semantic Web</strong></strong>. Es ermöglicht, Daten zu beschreiben, miteinander zu verknüpfen und maschinenlesbar zu machen.</p>



<figure class="wp-block-image size-full"><img data-recalc-dims="1" fetchpriority="high" decoding="async" width="871" height="871" src="https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/RDF.jpg?resize=871%2C871&#038;ssl=1" alt="RDF" class="wp-image-5148" srcset="https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/RDF.jpg?w=1024&amp;ssl=1 1024w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/RDF.jpg?resize=300%2C300&amp;ssl=1 300w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/RDF.jpg?resize=150%2C150&amp;ssl=1 150w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/RDF.jpg?resize=768%2C768&amp;ssl=1 768w" sizes="(max-width: 871px) 100vw, 871px" /></figure>



<p class="wp-block-paragraph">Man kann es für <strong>strukturierte Daten</strong>, <strong>Wissensgraphen</strong>, <strong>Linked Data</strong> und semantische Web-Technologien verwenden. Auch bietet es eine Grundlage für Anwendungen, die <strong>Datenintegration</strong>, <strong>Interoperabilität</strong> und <strong>automatisierte Verarbeitung</strong> erfordern.</p>



<h2 class="wp-block-heading"><strong>RDF-Grundprinzipien</strong></h2>



<h3 class="wp-block-heading">A<strong>ls Tripel-Modell</strong></h3>



<p class="wp-block-paragraph">RDF beschreibt Daten in Form von <strong>Tripeln</strong>, die aus drei Bestandteilen bestehen:</p>



<ul class="wp-block-list">
<li><strong>Subjekt</strong>: Das Ding, über das eine Aussage gemacht wird.</li>



<li><strong>Prädikat</strong>: Die Beziehung oder Eigenschaft des Subjekts.</li>



<li><strong>Objekt</strong>: Der Wert oder ein weiteres verknüpftes Objekt.</li>
</ul>



<p class="wp-block-paragraph"><strong>Beispiel:</strong><br>Max Mustermann hat einen Namen „Max Mustermann“.</p>



<ul class="wp-block-list">
<li><strong>Subjekt:</strong> <code>https://example.com/person/Max</code></li>



<li><strong>Prädikat:</strong> <code>https://schema.org/name</code></li>



<li><strong>Objekt:</strong> <code>"Max Mustermann"</code></li>
</ul>



<p class="wp-block-paragraph">In der Resource-Description-Framework-Notation kann dies wie folgt dargestellt werden:</p>



<pre class="wp-block-code"><code>&lt;https://example.com/person/Max&gt; &lt;https://schema.org/name&gt; "Max Mustermann" .</code></pre>



<p class="wp-block-paragraph">Visuell kann man sich Resource-Description-Framework als <strong>gerichteten Graphen</strong> vorstellen:</p>



<pre class="wp-block-code"><code>&#91;Max Mustermann] --(hat Name)--&gt; &#91;"Max Mustermann"]</code></pre>



<p class="wp-block-paragraph">Dieses Modell ermöglicht die einfache Verknüpfung und Erweiterung von Daten über verschiedene Systeme hinweg.</p>



<h3 class="wp-block-heading"><strong>URI als eindeutige Identifikation</strong></h3>



<p class="wp-block-paragraph">Das Resource-Description-Framework nutzt <strong>Uniform Resource Identifiers (URIs)</strong>, um Entitäten eindeutig zu identifizieren. Dies verhindert Mehrdeutigkeiten und ermöglicht eine klare Definition von Konzepten.</p>



<p class="wp-block-paragraph"><strong>Beispiel:</strong></p>



<ul class="wp-block-list">
<li><code>https://example.com/person/Max</code> – Eine eindeutige ID für Max Mustermann.</li>



<li><code>https://schema.org/name</code> – Ein standardisierter Begriff für „Name“.</li>
</ul>



<p class="wp-block-paragraph">Durch die Verwendung von <strong>URIs</strong> können RDF-Daten nahtlos mit anderen Quellen verknüpft werden.</p>



<h2 class="wp-block-heading"><strong>RDF-Serialisierungsformate</strong></h2>



<p class="wp-block-paragraph">Es kann in verschiedenen <strong>Serialisierungsformaten</strong> gespeichert und ausgetauscht werden. Die wichtigsten Formate sind:</p>



<h3 class="wp-block-heading"><strong>RDF/XML</strong></h3>



<p class="wp-block-paragraph">Ein XML-basiertes Format, aber oft schwer lesbar.</p>



<pre class="wp-block-code"><code>&lt;rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
         xmlns:schema="https://schema.org/"&gt;
  &lt;rdf:Description rdf:about="https://example.com/person/Max"&gt;
    &lt;schema:name&gt;Max Mustermann&lt;/schema:name&gt;
  &lt;/rdf:Description&gt;
&lt;/rdf:RDF&gt;</code></pre>



<h3 class="wp-block-heading"><strong>Turtle (TTL) – Lesbares Format</strong></h3>



<p class="wp-block-paragraph">Turtle ist kompakter und menschenfreundlicher.</p>



<pre class="wp-block-code"><code>@prefix schema: &lt;https://schema.org/&gt; .
&lt;https://example.com/person/Max&gt; schema:name "Max Mustermann" .</code></pre>



<h3 class="wp-block-heading"><strong>JSON-LD – Resource-Description-Framework in JSON</strong></h3>



<p class="wp-block-paragraph">Ideal für Webanwendungen, da es JSON-Strukturen nutzt.</p>



<pre class="wp-block-code"><code>{
  "@context": "https://schema.org/",
  "@id": "https://example.com/person/Max",
  "name": "Max Mustermann"
}</code></pre>



<h3 class="wp-block-heading"><strong>N-Triples – Einfache Textrepräsentation</strong></h3>



<p class="wp-block-paragraph">Jede Zeile enthält genau ein Tripel.</p>



<pre class="wp-block-code"><code>&lt;https://example.com/person/Max&gt; &lt;https://schema.org/name&gt; "Max Mustermann" .</code></pre>



<p class="wp-block-paragraph">Diese verschiedenen Formate ermöglichen die Nutzung von RDF in unterschiedlichen Umgebungen.</p>



<h2 class="wp-block-heading"><strong>Resource-Description-Framework-Vokabulare und Ontologien</strong></h2>



<h3 class="wp-block-heading"><strong>Standardisierte Vokabulare</strong></h3>



<p class="wp-block-paragraph">Das Resource-Description-Framework erlaubt die Verwendung bestehender <strong>Ontologien</strong> und <strong>Vokabulare</strong>, um Daten interoperabel zu machen. Einige weit verbreitete Standards sind:</p>



<ul class="wp-block-list">
<li><strong>Schema.org</strong> – Metadaten für Webinhalte (z.B. Personen, Organisationen, Produkte).</li>



<li><strong>Dublin Core (DC)</strong> – Standard für bibliografische Daten.</li>



<li><strong>FOAF (Friend of a Friend)</strong> – Modellierung von sozialen Netzwerken.</li>



<li><strong>SKOS (Simple Knowledge Organization System)</strong> – Für Taxonomien und Thesauri.</li>
</ul>



<p class="wp-block-paragraph"><strong>Beispiel für FOAF in Turtle:</strong></p>



<pre class="wp-block-code"><code>@prefix foaf: &lt;http://xmlns.com/foaf/0.1/&gt; .
&lt;https://example.com/person/Max&gt; a foaf:Person ;
    foaf:name "Max Mustermann" ;
    foaf:knows &lt;https://example.com/person/Anna&gt; .</code></pre>



<h2 class="wp-block-heading"><strong>Abfragen von RDF-Daten mit SPARQL</strong></h2>



<p class="wp-block-paragraph">SPARQL ist die <strong>Abfragesprache für RDF-Daten</strong>, ähnlich wie <a href="https://ceosbay.com/2022/10/29/structured-query-language-sql/">SQL</a> für relationale Datenbanken.</p>



<h3 class="wp-block-heading"><strong>Einfache SPARQL-Abfrage</strong></h3>



<p class="wp-block-paragraph">Diese Abfrage sucht den Namen von Max Mustermann:</p>



<pre class="wp-block-code"><code>PREFIX schema: &lt;https://schema.org/&gt;
SELECT ?name WHERE {
  &lt;https://example.com/person/Max&gt; schema:name ?name .
}</code></pre>



<h3 class="wp-block-heading"><strong>Komplexere Abfrage mit mehreren Bedingungen</strong></h3>



<p class="wp-block-paragraph">Finde alle Personen, die Max Mustermann kennen:</p>



<pre class="wp-block-code"><code>PREFIX foaf: &lt;http://xmlns.com/foaf/0.1/&gt;
SELECT ?person WHERE {
  &lt;https://example.com/person/Max&gt; foaf:knows ?person .
}</code></pre>



<p class="wp-block-paragraph">SPARQL ermöglicht das effiziente <strong>Filtern, Verknüpfen und Analysieren</strong> von RDF-Daten.</p>



<h2 class="wp-block-heading"><strong>RDF im Semantischen Web</strong></h2>



<p class="wp-block-paragraph">Das Resource-Description-Framework bildet die Grundlage des <strong>Semantic Web</strong>, das Informationen <strong>strukturiert und vernetzt</strong> bereitstellt. Vorteile sind:</p>



<p class="wp-block-paragraph"><strong>Maschinenlesbarkeit</strong> – Ermöglicht KI-gestützte Analysen.<br><strong>Datenintegration</strong> – Verbindung verteilter Datenquellen.<br><strong>Interoperabilität</strong> – Nutzung einheitlicher Standards.</p>



<p class="wp-block-paragraph"><strong>Beispielanwendungen:</strong></p>



<ul class="wp-block-list">
<li><strong>Wissensgraphen</strong> (z.B. Google Knowledge Graph).</li>



<li><strong>Linked Open Data</strong> (z.B. <a href="https://www.dbpedia.org">DBpedia</a>, <a href="https://www.wikidata.org/wiki/Wikidata:Main_Page">Wikidata</a>).</li>



<li><strong>Semantische Suchmaschinen</strong> (z.B. erweiterte Google-Suche).</li>
</ul>



<h2 class="wp-block-heading"><strong>Fazit</strong></h2>



<p class="wp-block-paragraph">Das Resource-Description-Framework ist eine <strong>leistungsstarke Technologie</strong>, die es ermöglicht, <strong>Daten zu beschreiben, zu verknüpfen und maschinenlesbar zu machen</strong>. Durch die Nutzung von <strong>SPARQL, Ontologien und Linked Data</strong> kann RDF für viele Anwendungen genutzt werden, z.B. im <strong>Wissensmanagement, E-Commerce, Bibliotheken, <a href="https://ceosbay.com/2023/04/02/erklaerung-kuenstliche-intelligenz/">KI</a> und semantischen Web-Technologien</strong>. Dank standardisierter <strong>Formate</strong> (Turtle, JSON-LD, RDF/XML) ist RDF vielseitig einsetzbar und zukunftssicher.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2025/02/21/rdf-resource-description-framework/">RDF (Resource Description Framework)</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2025/02/21/rdf-resource-description-framework/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">4761</post-id>	</item>
		<item>
		<title>REST &#8211; Schönheit der einfachen Architektur</title>
		<link>https://ceosbay.com/2022/12/23/erklaerung-rest/</link>
					<comments>https://ceosbay.com/2022/12/23/erklaerung-rest/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Fri, 23 Dec 2022 19:00:00 +0000</pubDate>
				<category><![CDATA[Cloud]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[7252]]></category>
		<category><![CDATA[Application]]></category>
		<category><![CDATA[Applikation]]></category>
		<category><![CDATA[Architektur]]></category>
		<category><![CDATA[Client]]></category>
		<category><![CDATA[CoAP]]></category>
		<category><![CDATA[Demand]]></category>
		<category><![CDATA[Get]]></category>
		<category><![CDATA[HATEOAS]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[https]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[Mkcol]]></category>
		<category><![CDATA[Move]]></category>
		<category><![CDATA[Parser]]></category>
		<category><![CDATA[Post]]></category>
		<category><![CDATA[Protokoll]]></category>
		<category><![CDATA[Rest]]></category>
		<category><![CDATA[Server]]></category>
		<category><![CDATA[SOAP]]></category>
		<category><![CDATA[URI]]></category>
		<category><![CDATA[URL]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[www]]></category>
		<category><![CDATA[xml]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1033</guid>

					<description><![CDATA[<p>REST &#8211; Representational State Transfer ist ein Paradigma für die Softwarearchitektur von verteilten Systemen, insbesondere für Webservices. Es ist eine Abstraktion der Struktur und des Verhaltens des WWW (World Wide Web). REST hat das Ziel, &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/">REST &#8211; Schönheit der einfachen Architektur</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">REST &#8211; Representational State Transfer ist ein Paradigma für die Softwarearchitektur von verteilten Systemen, insbesondere für Webservices. Es ist eine Abstraktion der Struktur und des Verhaltens des WWW (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 von anderen Architekturstilen.</p>



<p class="wp-block-paragraph">Der Zweck von REST liegt schwerpunktmäßig auf der Maschine-zu-Maschine-Kommunikation. REST stellt eine einfache Alternative zu ähnlichen Verfahren wie SOAP (Simple Object Access Protocol), WSDL (Web Services Description Language) und dem verwandten Verfahren RPC (Remote Procedure Call) dar. Anders als bei vielen verwandten Architekturen kodiert REST keine Methodeninformation in den URI (Uniform Resource Identifier), da der URI Ort und Namen der 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. B. Web- und Application-Server, https-fähige Clients, HTML- und XML-Parser, Sicherheitsmechanismen) vorhanden ist und viele Web-Dienste per se REST-konform sind. Eine Ressource kann dabei über verschiedene Medientypen dargestellt werden, auch Repräsentation der Ressource genannt.</p>



<p class="wp-block-paragraph">So ist ein Online-Dienst, der lediglich unveränderte Seiteninhalte nach dem Internetstandard https anbietet, bereits REST-konform. Dynamisch erzeugte Seiten folgen diesem Paradigma jedoch meistens 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 essenzielle REST-Eigenschaft erfüllt. So ist eine Webseite, auf der ständig die aktuelle Uhrzeit in immer demselben Format abrufbar ist, REST-konform.</p>



<p class="wp-block-paragraph">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.</p>



<h3 class="wp-block-heading">Kurze Zeitreise</h3>



<p class="wp-block-paragraph">Das REST-Paradigma entwickelte sich aus dem 1994 von Roy Fielding entworfenen https Object Model. Fielding entwickelte seine Idee von einem einheitlichen Konzept über die Jahre weiter, bis er 2000 den REST-Architekturstil im Rahmen seiner Dissertation (<a href="https://www.ics.uci.edu/~fielding/pubs/dissertation/fielding_dissertation.pdf" target="_blank" rel="noreferrer noopener">Hier der Link zu der Arbeit</a>) veröffentlichte. Das Programmierparadigma der „RESTful Application“ wurde allerdings häufig falsch umgesetzt und findet erst seit 2014 Anklang in der Welt des WWW. In seiner Arbeit geht Fielding dabei auf die verschiedenen Anforderungen ein, die für die Webarchitektur wichtig sind.</p>



<h3 class="wp-block-heading">Wie funktioniert REST?</h3>



<p class="wp-block-paragraph">Der Architektur-Stil verweist auf sechs Eigenschaften, die ein Dienst haben muss. Dabei ist nicht festgelegt, wie man diese Prinzipien implementieren muss. Fielding beschreibt für jedes Architekturprinzip dessen Vor- und Nachteile. Dabei handelt es sich um Client-Server, Zustandslosigkeit, Caching, Einheitliche Schnittstellen, Mehrschichtige Systeme und optional Code on Demand, auf die ich nachfolgend eingehen werde.</p>



<ul class="wp-block-list">
<li>Client-Server (Es gilt generell die Anforderung, dass alle Eigenschaften der Client-Server-Architektur gelten. Der Server stellt dabei einen Dienst bereit, der bei Bedarf vom Client abgefragt wird. 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.)<br></li>



<li>Zustandslosigkeit (Jede REST-Nachricht enthält alle Informationen, die für den Server bzw. für den Client notwendig sind, um die Nachricht zu interpretieren. Weder der Server noch die Anwendung soll Zustandsinformationen zwischen zwei Nachrichten speichern. Man spricht daher von einem zustandslosen (englisch: stateless) 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. Zustandslosigkeit in der hier beschriebenen Form begünstigt die Skalierbarkeit eines Webservices. Beispielsweise können eingehende Anfragen im Zuge der 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. Aus diesem Grund ist auf der Seite des Servers keine Sitzungsverwaltung erforderlich. In der Praxis nutzen deswegen viele https-basierte Anwendungen 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 Interpretieren mitgeschickt werden müssen, sind aufwendigere Abfragen nötig, als wenn sich der Server die Interaktionen merken würde.)<br></li>



<li>Caching (https-Caching soll genutzt werden, wobei aber 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. Wir kennen dies beispielsweise, wenn wir an einer Website unsere Änderungen vorgenommen haben aber die aktualisierten Informationen nach der Synchronisierung mit dem Server nicht richtig angezeigt werden bzw. lediglich die alten Informationen)<br></li>



<li>Einheitliche Schnittstelle (Dies ist das Hauptunterscheidungsmerkmal aller weiteren Architekturstile. Dabei besteht diese aus vier weiteren Eigenschaften.)</li>
</ul>



<ol class="wp-block-list" type="1">
<li>Die Adressierbarkeit von Ressourcen, bei der jede Information, die über einen URI kenntlich gemacht wird, als Ressource gekennzeichnet wird. Jeder REST-konforme Dienst eine eindeutige Adresse hat und dem 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 Mashups weiterzuverwenden.<br></li>



<li>Repräsentationen zur Veränderung von Ressourcen, wodurch die unter einer Adresse zugänglichen Dienste unterschiedliche Darstellungsformen (Repräsentationen) haben können. Ein REST-konformer Server kann je nachdem, was die Anwendung anfordert, verschiedene Repräsentationen einer Ressource ausliefern, z. B. in verschiedenen Sprachen oder Formaten (HTML, JSON oder XML) oder auch die Beschreibung oder Dokumentation des Dienstes. Die Veränderung einer Ressource (also deren aktuellen Status) soll nur über eine Repräsentation erfolgen.<br></li>



<li>Selbstbeschreibende Nachrichten, REST-Nachrichten sollen selbstbeschreibend sein. Dazu zählt u. a. die Verwendung von Standardmethoden. Über diese Standardmethoden lassen sich Ressourcen manipulieren.<br></li>



<li>„Hypermedia as the Engine of Application State“ (HATEOAS)&nbsp;laut Fielding die wichtigste Eigenschaft</li>
</ol>



<p class="wp-block-paragraph">Ziel ist die Einheitlichkeit der Schnittstelle und somit ihre einfache Nutzung.&nbsp;</p>



<ul class="wp-block-list">
<li>Mehrschichtige Systeme, bei dem die Systeme mehrschichtig aufgebaut sein sollen. Dadurch reicht es, dem Anwender lediglich eine Schnittstelle anzubieten. Dahinterliegende Ebenen können verborgen bleiben und somit die Architektur insgesamt vereinfachen. Vorteile dabei sind die bessere Skalierbarkeit der Server, sowie eine mögliche Abkapselung durch Firewalls. Durch Cache-Speicher an den Grenzen (z.B. vom Server zum Web) steigert man die Effizienz der Anfragen (Siehe Caching).<br></li>



<li>Code on Demand, wobei diese Forderung von Fielding optional ist. Unter Code on Demand versteht man die Übertragung an den Client Code erst im Bedarfsfall. Folglich zur lokalen Ausführung.&nbsp;Ein Beispiel hierfür wäre die Übertragung von JavaScript-Code bei einer HTML-Repräsentation.</li>
</ul>



<p class="wp-block-paragraph">Folglich kommt für die Umsetzung des REST-Paradigmas ein zustandsloses Client-Server-Protokoll zum Einsatz. Als Anwendungsschicht-Protokolle werden hauptsächlich https und https eingesetzt. Dies liegt unter anderem daran, dass sich diese im WWW etabliert haben, über einen vergleichsweisen 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.</p>



<p class="wp-block-paragraph">Während REST als Abstraktion des WWW keine spezielle Implementierung und kein spezielles Protokoll fordert, ist doch zu beobachten, dass fast ausschließlich https zum Einsatz kommt. Dadurch werden auch die Menge der Aktionen festgelegt.</p>



<p class="wp-block-paragraph">Wird über https zugegriffen, so gibt die verwendete https-Methode, darunter GET, POST, PUT und DELETE, an, welche Operation des Dienstes gewünscht ist. https schreibt vor, dass GET „safe“ (sicher) sein muss, was bedeutet, dass diese Methode nur Informationen beschafft und keine sonstigen Effekte verursacht. Die Methoden GET, HEAD, PUT und DELETE müssen laut https-Spezifikation idempotent (dasselbe) sein, was in diesem Zusammenhang bedeutet, dass das mehrfache Absenden der gleichen Anforderung sich nicht anders auswirkt als ein einzelner Aufruf. Abhängig von der Implementierung können noch weitere https-Befehle unterstützt werden. Dazu gehören COPY, MOVE, MKCOL, LOCK und UNLOCK des WebDAV-Protokolls, sowie LINK und UNLINK aus RFC 2068. Bei der Kommunikation über UDP kann zudem das CoAP aus RFC 7252 statt https eingesetzt werden, welches leicht abweichende Bedeutungen für GET, POST, PUT und DELETE besitzt.</p>



<h3 class="wp-block-heading">Fazit</h3>



<p class="wp-block-paragraph">Die meisten Unternehmen verwenden den REST-Architekturstil für die Entwicklung / Implementierung von Webdiensten, da es sich um eine einfache und benutzerfreundliche Oberfläche handelt, die weniger Schulung für die vorhandenen / neuen Mitglieder des Projekts erfordert. Unternehmen erwägen REST zusammen mit ihren vorhandenen Webdiensten.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/">REST &#8211; Schönheit der einfachen Architektur</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2022/12/23/erklaerung-rest/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1033</post-id>	</item>
	</channel>
</rss>
