<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://www.pyroneo.de//w/index.php?action=history&amp;feed=atom&amp;title=Synchronisierung</id>
	<title>Synchronisierung - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://www.pyroneo.de//w/index.php?action=history&amp;feed=atom&amp;title=Synchronisierung"/>
	<link rel="alternate" type="text/html" href="https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;action=history"/>
	<updated>2026-04-05T17:44:22Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in PyroNeo Wiki</subtitle>
	<generator>MediaWiki 1.39.13</generator>
	<entry>
		<id>https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1429&amp;oldid=prev</id>
		<title>Admin am 28. Januar 2012 um 22:23 Uhr</title>
		<link rel="alternate" type="text/html" href="https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1429&amp;oldid=prev"/>
		<updated>2012-01-28T22:23:36Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;de&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Nächstältere Version&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Version vom 28. Januar 2012, 22:23 Uhr&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l6&quot;&gt;Zeile 6:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 6:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Jeder Empfänger unterhält einen Sequenzzähler, nachfolgend Sequenznummer genannt. Diese Nummer dient zur Unterscheidung zwischen &amp;quot;alten&amp;quot; und &amp;quot;aktuellen&amp;quot; Funkbefehlen. Die Nummer wird beim Ausschalten (oder Spannungsverlust) eines Moduls nicht-flüchtig gesichert und bietet so einen eindeutigen Anhaltspunkt dafür, welche Befehle bereits empfangen und ausgewertet wurden.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Jeder Empfänger unterhält einen Sequenzzähler, nachfolgend Sequenznummer genannt. Diese Nummer dient zur Unterscheidung zwischen &amp;quot;alten&amp;quot; und &amp;quot;aktuellen&amp;quot; Funkbefehlen. Die Nummer wird beim Ausschalten (oder Spannungsverlust) eines Moduls nicht-flüchtig gesichert und bietet so einen eindeutigen Anhaltspunkt dafür, welche Befehle bereits empfangen und ausgewertet wurden.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Hochsichere &lt;/del&gt;Befehle ===&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Normale &lt;/ins&gt;Befehle ===&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Hochsichere Befehle enthalten &lt;/del&gt;selbst eine solche Sequenznummer die vom Sender automatisch hoch gezählt wird. Jeder Befehl ist darüber hinaus mit einem [http://de.wikipedia.org/wiki/Kryptologische_Hashfunktion kryptographischen Hash] abgesichert, so dass sich ein Befehl nicht von einer unbeteiligten Person fälschen lässt.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Jeder Befehl enthält &lt;/ins&gt;selbst eine solche Sequenznummer&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;, &lt;/ins&gt;die vom Sender automatisch hoch gezählt wird. Jeder Befehl ist darüber hinaus mit einem [http://de.wikipedia.org/wiki/Kryptologische_Hashfunktion kryptographischen Hash] abgesichert, so dass sich ein Befehl nicht von einer unbeteiligten Person fälschen lässt.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Wenn nun ein Modul einen solchen Befehl empfängt, prüft es zunächst, ob der enthaltene Hash gültig ist (es verwirft also Nachrichten, die nicht von einer Systemkomponente erzeugt wurden). Sollte hierbei ein Fehler festgestellt werden, wird die Nachricht sofort verworfen. Wenn die Nachricht gültig signiert ist, wird anschließend geprüft, ob die enthaltene Sequenznummer größer ist als die im Modul gespeicherte Sequenznummer. Nur wenn dies der Fall ist, ist der Befehl &amp;quot;aktuell&amp;quot; und darf ausgeführt werden. Andernfalls wurde der Befehl bereits benutzt bzw. das Modul hat bereits einen Befehl mit einer größeren Sequenznummer erhalten und der empfangene Befehl ist damit zu alt.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Wenn nun ein Modul einen solchen Befehl empfängt, prüft es zunächst, ob der enthaltene Hash gültig ist (es verwirft also Nachrichten, die nicht von einer &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;anderen &lt;/ins&gt;Systemkomponente erzeugt wurden). Sollte hierbei ein Fehler festgestellt werden, wird die Nachricht sofort verworfen. Wenn die Nachricht gültig signiert ist, wird anschließend geprüft, ob die enthaltene Sequenznummer größer ist als die im Modul gespeicherte Sequenznummer. Nur wenn dies der Fall ist, ist der Befehl &amp;quot;aktuell&amp;quot; und darf ausgeführt werden. Andernfalls wurde der Befehl bereits benutzt bzw. das Modul hat bereits einen Befehl mit einer größeren Sequenznummer erhalten und der empfangene Befehl ist damit zu alt.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== Probleme des Verfahrens ===&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== Probleme des Verfahrens ===&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Dieses Verfahren wird einige Probleme auf:&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Dieses Verfahren wird einige Probleme auf:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* Eventuell ist der Sender (und davon kann es ja mehrere geben, so lange der eingetragene Systemschlüssel identisch ist) auf einem Sequenznummer-Stand &amp;quot;hinter&amp;quot; dem befehlsempfangenen Modul. Es muss also ein Verfahren geben, den Sender an die größte Sequenznummer anzugleichen die angesprochen werden soll. Dies ist &amp;#039;&amp;#039;ein&amp;#039;&amp;#039; Teil der Synchronisierung.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* Eventuell ist der Sender (und davon kann es ja mehrere geben, so lange der eingetragene Systemschlüssel identisch ist) auf einem Sequenznummer-Stand &amp;quot;hinter&amp;quot; dem befehlsempfangenen Modul. Es muss also ein Verfahren geben, den Sender an die größte Sequenznummer anzugleichen die angesprochen werden soll. Dies ist &amp;#039;&amp;#039;ein&amp;#039;&amp;#039; Teil der Synchronisierung &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;und des Anlernens&lt;/ins&gt;.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* Es ist möglich, dass das Modul auf einem Sequenznummer-Stand ist, der nicht mehr der letzten ausgesendeten Sequenznummer entspricht. Folgendes Szenario:&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* Es ist möglich, dass das Modul auf einem Sequenznummer-Stand ist, der nicht mehr der letzten ausgesendeten Sequenznummer entspricht. Folgendes Szenario:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l26&quot;&gt;Zeile 26:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 26:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Erkennen eines Moduls fragt der Commander dessen Sequenznummer signiert ab. Dadurch ist der Commander anschließend auf dem aktuellen Stand und sendet nur noch Befehle aus, die eine höhere Sequenznummer als die des Moduls beinhalten.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Erkennen eines Moduls fragt der Commander dessen Sequenznummer signiert ab. Dadurch ist der Commander anschließend auf dem aktuellen Stand und sendet nur noch Befehle aus, die eine höhere Sequenznummer als die des Moduls beinhalten.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==== Lösung für Problem 2 (falscher Stand des Moduls) ====&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==== &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Sicherer Modus ====&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Im sicheren Modus wird genau dieses zweite Problem nicht adressiert - so lange ein empfangener Befehl eine Sequenznummer enthält, die größer ist als die aktuelle Modul-Sequenznummer, wird der Befehl akzeptiert. Die verbleibenden Angriffsmöglichkeiten sind gegeben, erfordern jedoch einen hohen technischen Aufwand.&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt; &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Als Vorteil zu nennen ist hier die Möglichkeit, Module auch ohne [[Freischaltung]] unidirektional zu benutzen, da die Module nicht erst bidirektional angesprochen werden müssen.&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt; &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;==== Hochsicherer Modus: &lt;/ins&gt;Lösung für Problem 2 (falscher Stand des Moduls) ====&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Das Modul kann davon ausgehen, dass der Commander nur einen signierten Befehl an ein Modul sendet, wenn dieses auch vorhanden ist und signiert antwortet (Abfrage der Sequenznummer, siehe Problem 1). Wenn also ein Befehl generiert wird, der direkt an das Modul adressiert ist, so kann daran die aktuelle Sequenznummer abgelesen werden.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Das Modul kann davon ausgehen, dass der Commander nur einen signierten Befehl an ein Modul sendet, wenn dieses auch vorhanden ist und signiert antwortet (Abfrage der Sequenznummer, siehe Problem 1). Wenn also ein Befehl generiert wird, der direkt an das Modul adressiert ist, so kann daran die aktuelle Sequenznummer abgelesen werden.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Einschalten wartet das Modul also, bis es einen gültigen Synchronisationsbefehl bekommen hat, der ausschließlich an dieses Modul adressiert war. Erst danach werden signierte Befehle als &amp;quot;gültig&amp;quot; ausgeführt. So wird verhindert, dass es zu fehlerhaften Zündungen kommen kann.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Einschalten wartet das Modul also, bis es einen gültigen Synchronisationsbefehl bekommen hat, der ausschließlich an dieses Modul adressiert war. Erst danach werden signierte Befehle als &amp;quot;gültig&amp;quot; ausgeführt. So wird verhindert, dass es zu fehlerhaften Zündungen kommen kann.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;(In der Praxis wird nur ein bestimmter Befehl akzeptiert, der gleichzeitig den Systemcode des Moduls ändert, um bei komplett neuen Aufbauten - bei denen auch der Commander gewechselt hat - auf der sicheren Seite zu sein).&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== Ablauf der Synchronisation ===&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== Ablauf der Synchronisation ===&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l43&quot;&gt;Zeile 43:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 46:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Beide Geräte benutzen jetzt die höchste bekannte Sequenznummer; so ist sichergestellt, dass alte Befehle nicht mehr angenommen werden können und die beiden Geräte trotzdem hochsicher miteinander kommunizieren können.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Beide Geräte benutzen jetzt die höchste bekannte Sequenznummer; so ist sichergestellt, dass alte Befehle nicht mehr angenommen werden können und die beiden Geräte trotzdem hochsicher miteinander kommunizieren können.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;== Nicht sicherheitsrelevante Befehle ==&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Befehle, die selbst nicht sicherheitsrelevant sind (z.B. Abruf von Statusinformationen) werden grundsätzlich unabhängig von der Signatur ausgeführt und bedürfen daher keine sicheren Befehle. Die so generierten Befehle können etwas schneller übertragen werden, weswegen diese Unterscheidung vorgenommen wird.&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Kategorie:Technik]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Kategorie:Technik]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Kategorie:Software]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Kategorie:Software]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Hochsichere Befehle werden vor der Synchronisierung nicht ausgeführt, da es sich um veraltete Befehle handeln könnte.&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
	<entry>
		<id>https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1099&amp;oldid=prev</id>
		<title>Admin am 31. Oktober 2011 um 09:58 Uhr</title>
		<link rel="alternate" type="text/html" href="https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1099&amp;oldid=prev"/>
		<updated>2011-10-31T09:58:31Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;de&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Nächstältere Version&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Version vom 31. Oktober 2011, 09:58 Uhr&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot;&gt;Zeile 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Die Synchronisierung bezeichnet einen Vorgang, der einmalig vor jeder [[Hochsicherheitsmodus|hochsicheren Kommunikation]] zwischen Sender und Empfänger durchgeführt wird, um die hochsichere Kommunikation aufzubauen. Dabei werden Sender und Empfänger &amp;quot;auf den gleichen Stand&amp;quot; gebracht. Alte Funkbefehle können so weder vor noch nach der Synchronisierung benutzt werden.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Die Synchronisierung bezeichnet einen Vorgang, der einmalig vor jeder [[Hochsicherheitsmodus|hochsicheren Kommunikation]] zwischen Sender und Empfänger durchgeführt wird, um die hochsichere Kommunikation aufzubauen. Dabei werden Sender und Empfänger &amp;quot;auf den gleichen Stand&amp;quot; gebracht. Alte Funkbefehle können so weder vor noch nach der Synchronisierung benutzt werden&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;, hochsichere Befehle werden jedoch erst nach der erfolgreichen Synchronisierung ausgeführt.&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt; &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Aus diesem Grund ist für die hochsichere Verbindung zumindest einmalig nach dem Einschalten eines Moduls eine bidirektionale Kommunikationsmöglichkeit erforderlich. Sollte diese nicht zur Verfügung stehen, kann alternativ die [[Freischaltung]] benutzt werden, die jedoch nicht immer vollständig gegen mutwillige Angriffe geschützt ist&lt;/ins&gt;.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Technischer Hintergrund ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Technischer Hintergrund ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
	<entry>
		<id>https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1098&amp;oldid=prev</id>
		<title>Admin: /* Lösung */</title>
		<link rel="alternate" type="text/html" href="https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1098&amp;oldid=prev"/>
		<updated>2011-10-31T08:59:00Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Lösung&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;de&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Nächstältere Version&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Version vom 31. Oktober 2011, 08:59 Uhr&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l21&quot;&gt;Zeile 21:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 21:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;(Übrigens hat jedes andere Zündsystem genau dieses letztgenannte Problem: Dort lassen sich, egal welche Verschlüsselung benutzt wird, sämtliche Befehle aufzeichnen und dadurch ungewollte Zündungen jederzeit auslösen!)&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;(Übrigens hat jedes andere Zündsystem genau dieses letztgenannte Problem: Dort lassen sich, egal welche Verschlüsselung benutzt wird, sämtliche Befehle aufzeichnen und dadurch ungewollte Zündungen jederzeit auslösen!)&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;=== Lösung &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;===&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;=&lt;/ins&gt;=== Lösung für Problem 1 (falscher Stand des Commanders) ====&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Folgende Lösungen werden &lt;/del&gt;für &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;die beiden Probleme benutzt:&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt; &lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;==== &lt;/del&gt;Problem 1 (falscher Stand des Commanders) ====&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Erkennen eines Moduls fragt der Commander dessen Sequenznummer signiert ab. Dadurch ist der Commander anschließend auf dem aktuellen Stand und sendet nur noch Befehle aus, die eine höhere Sequenznummer als die des Moduls beinhalten.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Erkennen eines Moduls fragt der Commander dessen Sequenznummer signiert ab. Dadurch ist der Commander anschließend auf dem aktuellen Stand und sendet nur noch Befehle aus, die eine höhere Sequenznummer als die des Moduls beinhalten.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==== Problem 2 (falscher Stand des Moduls) ====&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==== &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Lösung für &lt;/ins&gt;Problem 2 (falscher Stand des Moduls) ====&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Das Modul kann davon ausgehen, dass der Commander nur einen signierten Befehl an ein Modul sendet, wenn dieses auch vorhanden ist und signiert antwortet (Abfrage der Sequenznummer, siehe Problem 1). Wenn also ein Befehl generiert wird, der direkt an das Modul adressiert ist, so kann daran die aktuelle Sequenznummer abgelesen werden.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Das Modul kann davon ausgehen, dass der Commander nur einen signierten Befehl an ein Modul sendet, wenn dieses auch vorhanden ist und signiert antwortet (Abfrage der Sequenznummer, siehe Problem 1). Wenn also ein Befehl generiert wird, der direkt an das Modul adressiert ist, so kann daran die aktuelle Sequenznummer abgelesen werden.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Einschalten wartet das Modul also, bis es einen gültigen Synchronisationsbefehl bekommen hat, der ausschließlich an dieses Modul adressiert war. Erst danach werden signierte Befehle als &amp;quot;gültig&amp;quot; ausgeführt. So wird verhindert, dass es zu fehlerhaften Zündungen kommen kann.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Nach dem Einschalten wartet das Modul also, bis es einen gültigen Synchronisationsbefehl bekommen hat, der ausschließlich an dieses Modul adressiert war. Erst danach werden signierte Befehle als &amp;quot;gültig&amp;quot; ausgeführt. So wird verhindert, dass es zu fehlerhaften Zündungen kommen kann.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
	<entry>
		<id>https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1097&amp;oldid=prev</id>
		<title>Admin: Die Seite wurde neu angelegt: „Die Synchronisierung bezeichnet einen Vorgang, der einmalig vor jeder hochsicheren Kommunikation zwischen Sender und Empfänger durchgef…“</title>
		<link rel="alternate" type="text/html" href="https://www.pyroneo.de//w/index.php?title=Synchronisierung&amp;diff=1097&amp;oldid=prev"/>
		<updated>2011-10-31T08:58:24Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „Die Synchronisierung bezeichnet einen Vorgang, der einmalig vor jeder &lt;a href=&quot;/wiki/Hochsicherheitsmodus&quot; title=&quot;Hochsicherheitsmodus&quot;&gt;hochsicheren Kommunikation&lt;/a&gt; zwischen Sender und Empfänger durchgef…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Die Synchronisierung bezeichnet einen Vorgang, der einmalig vor jeder [[Hochsicherheitsmodus|hochsicheren Kommunikation]] zwischen Sender und Empfänger durchgeführt wird, um die hochsichere Kommunikation aufzubauen. Dabei werden Sender und Empfänger &amp;quot;auf den gleichen Stand&amp;quot; gebracht. Alte Funkbefehle können so weder vor noch nach der Synchronisierung benutzt werden.&lt;br /&gt;
&lt;br /&gt;
== Technischer Hintergrund ==&lt;br /&gt;
Jeder Empfänger unterhält einen Sequenzzähler, nachfolgend Sequenznummer genannt. Diese Nummer dient zur Unterscheidung zwischen &amp;quot;alten&amp;quot; und &amp;quot;aktuellen&amp;quot; Funkbefehlen. Die Nummer wird beim Ausschalten (oder Spannungsverlust) eines Moduls nicht-flüchtig gesichert und bietet so einen eindeutigen Anhaltspunkt dafür, welche Befehle bereits empfangen und ausgewertet wurden.&lt;br /&gt;
&lt;br /&gt;
=== Hochsichere Befehle ===&lt;br /&gt;
Hochsichere Befehle enthalten selbst eine solche Sequenznummer die vom Sender automatisch hoch gezählt wird. Jeder Befehl ist darüber hinaus mit einem [http://de.wikipedia.org/wiki/Kryptologische_Hashfunktion kryptographischen Hash] abgesichert, so dass sich ein Befehl nicht von einer unbeteiligten Person fälschen lässt.&lt;br /&gt;
&lt;br /&gt;
Wenn nun ein Modul einen solchen Befehl empfängt, prüft es zunächst, ob der enthaltene Hash gültig ist (es verwirft also Nachrichten, die nicht von einer Systemkomponente erzeugt wurden). Sollte hierbei ein Fehler festgestellt werden, wird die Nachricht sofort verworfen. Wenn die Nachricht gültig signiert ist, wird anschließend geprüft, ob die enthaltene Sequenznummer größer ist als die im Modul gespeicherte Sequenznummer. Nur wenn dies der Fall ist, ist der Befehl &amp;quot;aktuell&amp;quot; und darf ausgeführt werden. Andernfalls wurde der Befehl bereits benutzt bzw. das Modul hat bereits einen Befehl mit einer größeren Sequenznummer erhalten und der empfangene Befehl ist damit zu alt.&lt;br /&gt;
&lt;br /&gt;
=== Probleme des Verfahrens ===&lt;br /&gt;
Dieses Verfahren wird einige Probleme auf:&lt;br /&gt;
&lt;br /&gt;
* Eventuell ist der Sender (und davon kann es ja mehrere geben, so lange der eingetragene Systemschlüssel identisch ist) auf einem Sequenznummer-Stand &amp;quot;hinter&amp;quot; dem befehlsempfangenen Modul. Es muss also ein Verfahren geben, den Sender an die größte Sequenznummer anzugleichen die angesprochen werden soll. Dies ist &amp;#039;&amp;#039;ein&amp;#039;&amp;#039; Teil der Synchronisierung.&lt;br /&gt;
&lt;br /&gt;
* Es ist möglich, dass das Modul auf einem Sequenznummer-Stand ist, der nicht mehr der letzten ausgesendeten Sequenznummer entspricht. Folgendes Szenario:&lt;br /&gt;
: Ein Benutzer hat 15 Module, die alle mit dem gleichen Systemschlüssel programmiert sind. Alle Module sind auf dem Sequenznummer-Stand 7. Zu einem Feuerwerk werden nun 10 Module mitgenommen, 5 bleiben im Lager zurück weil sie nicht benötigt werden. Während die Show geschossen wird, generiert der Commander gültige Befehle mit den Sequenznummern 8 - 109, die von den 10 Zündmodulen im Feld als gültig angenommen und ausgeführt werden. Nach der Show wird das Equipment wieder ins Lager geräumt.&lt;br /&gt;
: Ein Angreifer hat nun diese vom Commander generierten Funkbefehle aufgezeichnet (dazu ist keine Kentniss des Inhaltes notwendig, auch verschlüsselte Befehle könnten so verwendet werden). Bei der nächsten Show die unser Benutzer durchführen möchte liegen nun alle 15 Zündmodule im Feld und wurden gerade eingeschaltet. Sie hatten also noch keinen Kontakt mit dem Commander. Fünf der 15 Module stehen immer noch bei Sequenznummer 7, die restlichen 10 Module stehen bei Sequenznummer 109.&lt;br /&gt;
: Der Angreifer könnte jetzt seine von der vorherigen Show aufgezeichneten Befehle (mit Sequenznummer 8-109) an zumindest fünf der 15 Module abschicken und diese würden sie als gültig betrachten und ausführen. Dadurch könnte im Zweifel die komplette Show der letzten Woche auf diesen fünf Modulen gezündet werden, was natürlich nicht akzeptabel ist.&lt;br /&gt;
&lt;br /&gt;
(Übrigens hat jedes andere Zündsystem genau dieses letztgenannte Problem: Dort lassen sich, egal welche Verschlüsselung benutzt wird, sämtliche Befehle aufzeichnen und dadurch ungewollte Zündungen jederzeit auslösen!)&lt;br /&gt;
&lt;br /&gt;
=== Lösung ===&lt;br /&gt;
Folgende Lösungen werden für die beiden Probleme benutzt:&lt;br /&gt;
&lt;br /&gt;
==== Problem 1 (falscher Stand des Commanders) ====&lt;br /&gt;
Nach dem Erkennen eines Moduls fragt der Commander dessen Sequenznummer signiert ab. Dadurch ist der Commander anschließend auf dem aktuellen Stand und sendet nur noch Befehle aus, die eine höhere Sequenznummer als die des Moduls beinhalten.&lt;br /&gt;
&lt;br /&gt;
==== Problem 2 (falscher Stand des Moduls) ====&lt;br /&gt;
Das Modul kann davon ausgehen, dass der Commander nur einen signierten Befehl an ein Modul sendet, wenn dieses auch vorhanden ist und signiert antwortet (Abfrage der Sequenznummer, siehe Problem 1). Wenn also ein Befehl generiert wird, der direkt an das Modul adressiert ist, so kann daran die aktuelle Sequenznummer abgelesen werden.&lt;br /&gt;
Nach dem Einschalten wartet das Modul also, bis es einen gültigen Synchronisationsbefehl bekommen hat, der ausschließlich an dieses Modul adressiert war. Erst danach werden signierte Befehle als &amp;quot;gültig&amp;quot; ausgeführt. So wird verhindert, dass es zu fehlerhaften Zündungen kommen kann.&lt;br /&gt;
&lt;br /&gt;
(In der Praxis wird nur ein bestimmter Befehl akzeptiert, der gleichzeitig den Systemcode des Moduls ändert, um bei komplett neuen Aufbauten - bei denen auch der Commander gewechselt hat - auf der sicheren Seite zu sein).&lt;br /&gt;
&lt;br /&gt;
=== Ablauf der Synchronisation ===&lt;br /&gt;
* Schritt 1&lt;br /&gt;
: Der Commander sendet den signierten Befehl &amp;quot;COMMAND_GET_SEQUENCE&amp;quot; an das Modul - dieser Befehl ist nicht signiert.&lt;br /&gt;
* Schritt 2&lt;br /&gt;
: Das Modul antwortet &amp;quot;ANSWER_GET_SEQUENCE&amp;quot; signiert mit seiner aktuellen Sequenznummer.&lt;br /&gt;
* Schritt 3&lt;br /&gt;
: Der Commander prüft die Signatur und übernimmt eventuell die Sequenznummer (wenn Sie größer ist als seine eigene). Er schickt daraufhin den Befehl &amp;quot;COMMAND_SET_SEQUENCE&amp;quot; signiert mit seiner dann aktuellen Sequenznummer und inkludiert außerdem seine Systemnummer.&lt;br /&gt;
* Schritt 4&lt;br /&gt;
: Das Modul empfängt diese Nachricht und setzt seine aktuelle Systemnummer entsprechend (alte Befehle eines anderen Commanders werden nicht mehr angenommen), außerdem wird die Sequenznummer auf den Stand des Commanders gesetzt.&lt;br /&gt;
&lt;br /&gt;
Beide Geräte benutzen jetzt die höchste bekannte Sequenznummer; so ist sichergestellt, dass alte Befehle nicht mehr angenommen werden können und die beiden Geräte trotzdem hochsicher miteinander kommunizieren können.&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Technik]]&lt;br /&gt;
[[Kategorie:Software]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Hochsichere Befehle werden vor der Synchronisierung nicht ausgeführt, da es sich um veraltete Befehle handeln könnte.&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
</feed>