Zum Inhalt springen

„Abstract Syntax Notation One“ – Versionsunterschied

aus Wikipedia, der freien Enzyklopädie
[gesichtete Version][gesichtete Version]
Inhalt gelöscht Inhalt hinzugefügt
K Änderungen von 62.218.60.146 (Diskussion) auf die letzte Version von Trustable zurückgesetzt
 
(24 dazwischenliegende Versionen von 13 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
Die '''Abstract Syntax Notation One''' ('''ASN.1''', {{deS|''Abstrakte Syntaxnotation Eins''}}) ist eine [[Beschreibungssprache]] zur Definition von [[Datenstruktur]]en sowie Festlegungen zur Umsetzung von Datenstrukturen und Elementen in ein netzeinheitliches Format. Sie ist gemeinsamer Standard der [[ITU-T]] (International Telecommunication Union – Telecommunication Standardization Sector) und der [[Internationale Organisation für Normung|ISO]] (Internationale Organisation für Normung).
Die '''Abstract Syntax Notation One''' ('''ASN.1'''; {{deS|Abstrakte Syntaxnotation Eins}}) ist eine [[Computersprache#Beschreibungssprachen|Beschreibungssprache]] zur Definition von [[Datenstruktur]]en sowie Festlegungen zur Umsetzung von Datenstrukturen und Elementen in ein netzeinheitliches Format. Sie ist gemeinsamer Standard der [[ITU-T]] (International Telecommunication Union – Telecommunication Standardization Sector) und der [[Internationale Organisation für Normung|ISO]] (Internationale Organisation für Normung).


Das Wort ''Abstract'' im Namen bedeutet, dass zwar die (abstrakte) Struktur der Daten festgelegt wird, nicht aber die (konkrete) Schreibweise, also wie die einzelnen Bits über die Leitung geschickt oder in Dateien gespeichert werden. Durch diese Trennung zwischen Inhalt und Form ist es möglich, je nach Verwendungszweck eine dafür geeignete Schreibweise (Kodierung) zu verwenden.
Der Standard dient der abstrakten Beschreibung von Datentypen, ohne auf die rechnerinterne Darstellung einzugehen. Die Notation ist in den ITU-T-Standards X.680ff definiert. Die zugehörigen Standards X.690ff definieren verschiedene ''Encoding Rules'' (Kodierungsregeln), wie die ASN.1-Datenwerte auf Bit-Ebene kodiert werden. Mit Hilfe von ASN.1 und einer gemeinsamen Kodierungsregel können Systeme mit unterschiedlichen internen Datendarstellungen Nachrichten austauschen.

Das Wort ''Syntax'' im Namen bedeutet, dass diese Notation nur festlegt, welche Form die Daten haben. Sie legt jedoch nicht fest, wie diese Daten interpretiert werden. So kann mit ASN.1 zum Beispiel eine „Folge zweier Zahlen, nämlich 7 und 13“ beschrieben werden. Was diese Zahlen inhaltlich bedeuten, wird jedoch nicht von ASN.1 festgelegt, sondern von der Anwendung, die ASN.1 verwendet.

Die Notation ist in den ITU-T-Standards X.680ff definiert. Die zugehörigen Standards X.690ff definieren verschiedene ''Encoding Rules'' (Kodierungsregeln), wie die ASN.1-Datenwerte auf Bit-Ebene kodiert werden. Mit Hilfe von ASN.1 und einer gemeinsamen Kodierungsregel können Systeme mit unterschiedlichen internen Datendarstellungen Nachrichten austauschen.


ASN.1 ist eine verbreitete Möglichkeit, die Nachrichtenelemente von Protokollen des [[OSI-Modell]]s eindeutig zu beschreiben, und wird von OSI-konformen Techniken wie [[X.500]] und [[X.509]], aber auch von [[Internetprotokollfamilie|Internetprotokollen]] wie [[Simple Network Management Protocol|SNMP]] oder [[LDAP]] verwendet. Breite Anwendung findet ASN.1 auch im Telekommunikationsbereich, z. B. bei den Standards [[Global System for Mobile Communications|GSM]] für die Abrechnung von [[Roaming]]gesprächen in [[TAP3]]-Dateien und [[Universal Mobile Telecommunications System|UMTS]].
ASN.1 ist eine verbreitete Möglichkeit, die Nachrichtenelemente von Protokollen des [[OSI-Modell]]s eindeutig zu beschreiben, und wird von OSI-konformen Techniken wie [[X.500]] und [[X.509]], aber auch von [[Internetprotokollfamilie|Internetprotokollen]] wie [[Simple Network Management Protocol|SNMP]] oder [[LDAP]] verwendet. Breite Anwendung findet ASN.1 auch im Telekommunikationsbereich, z. B. bei den Standards [[Global System for Mobile Communications|GSM]] für die Abrechnung von [[Roaming]]gesprächen in [[TAP3]]-Dateien und [[Universal Mobile Telecommunications System|UMTS]].
Zeile 9: Zeile 13:
== {{Anker|Syntax}}Syntax und Semantik ==
== {{Anker|Syntax}}Syntax und Semantik ==
ASN.1 wird in einer [[Backus-Naur-Form|BNF]]-ähnlichen Darstellung beschrieben, z. B.:
ASN.1 wird in einer [[Backus-Naur-Form|BNF]]-ähnlichen Darstellung beschrieben, z. B.:

Record ::= SEQUENCE {
Record ::= SEQUENCE {
kopf Header,
kopf Header,
daten Data OPTIONAL
daten Data OPTIONAL
}
}

Header ::= IA5String
Header ::= IA5String

Data ::= SET OF INTEGER
Data ::= SET OF INTEGER


Im nächsten Beispiel wird ein ''Modul'' vereinbart. Es ist möglich, dieses Modul auch mittels eines [[Object Identifier]]s zu finden. Dies geschieht, indem man dem Modulnamen eine ''Objektreferenz'' (''Object Reference'') anfügt, z. B.:
Im nächsten Beispiel wird ein ''Modul'' vereinbart. Es ist möglich, dieses Modul auch mittels eines [[Object Identifier]]s zu finden. Dies geschieht, indem man dem Modulnamen eine ''Objektreferenz'' (''Object Reference'') anfügt, z. B.:
Modul-name {joint-iso-itu-t(2) example(999)} DEFINITIONS ::=
Modul-name {joint-iso-itu-t(2) example(999)} DEFINITIONS ::=
BEGIN
BEGIN
Daten-struktur ::= SEQUENCE {
teil INTEGER,
Daten-struktur ::= SEQUENCE
fragment IA5String
{
}
teil INTEGER,
fragment IA5String
}
END
END


Wie in diesem Beispiel ersichtlich ist, wird vor dem Begriff <tt>DEFINITIONS</tt> mittels der geschweiften Klammern eine Objektreferenz, also eine ID angelegt. Die Objektreferenz verweist auf die Stelle in einem Baum von Referenzen bzw. Vereinbarungen, an der das richtige Objekt zu finden ist. Die ID aus diesem Beispiel verweist auf die erste Wurzel in der ersten Ebene der Verweisstruktur. Module in der Form, wie oben eines dargestellt ist, sind nötig, um eine Vereinbarung zu treffen, wie Daten übertragen werden sollen. Daten, die wie im obigen Beispiel definiert sind, werden wie folgt übertragen: <code>{ 2, "Teil2" }</code>.
Vor dem Begriff <span style="font-family:monospace;">DEFINITIONS</span> wird mittels der geschweiften Klammern eine Objektreferenz, also eine ID angelegt. Die Objektreferenz verweist auf die Stelle in einem Baum von Referenzen bzw. Vereinbarungen, an der das richtige Objekt zu finden ist. Die ID aus diesem Beispiel verweist auf die erste Wurzel in der ersten Ebene der Verweisstruktur. Module in der oben dargestellten Form sind nötig, um eine Vereinbarung zu treffen, wie Daten übertragen werden sollen. Daten, die wie im obigen Beispiel definiert sind, werden wie folgt übertragen: <code>{ 2, "Teil2" }</code>.


ASN.1 kennt dazu u.a.
ASN.1 kennt dazu u.&nbsp;a.
* Elementare Typen, z.&nbsp;B.
* Elementare Typen, z.&nbsp;B.
** <tt>BIT STRING</tt> (binäre Zeichenfolge)
** <span style="font-family:monospace;">BIT STRING</span> (binäre Zeichenfolge)
** <tt>BOOLEAN</tt>
** <span style="font-family:monospace;">BOOLEAN</span>
** <tt>IA5String</tt> (nach IA5-Tabelle kodierte Zeichenfolge, siehe [[ISO 646]])
** <span style="font-family:monospace;">IA5String</span> (nach IA5-Tabelle kodierte Zeichenfolge, siehe [[ISO 646]])
** <tt>INTEGER</tt>
** <span style="font-family:monospace;">INTEGER</span>
* Zusammengesetzte Typen, z.&nbsp;B.
* Zusammengesetzte Typen, z.&nbsp;B.
** <tt>CHOICE</tt> (Summentyp)
** <span style="font-family:monospace;">CHOICE</span> (Summentyp)
** <tt>SEQUENCE</tt> (geordnete Abfolge verschiedener Typen)
** <span style="font-family:monospace;">SEQUENCE</span> (geordnete Abfolge verschiedener Typen)
** <tt>SEQUENCE OF <Typ></tt> (geordnete Abfolge gleichen Typs)
** <span style="font-family:monospace;">SEQUENCE OF <Typ></span> (geordnete Abfolge gleichen Typs)
** <tt>SET</tt> (ungeordnete Abfolge verschiedener Typen)
** <span style="font-family:monospace;">SET</span> (ungeordnete Abfolge verschiedener Typen)
** <tt>SET OF <Typ></tt> (ungeordnete Abfolge gleichen Typs)
** <span style="font-family:monospace;">SET OF <Typ></span> (ungeordnete Abfolge gleichen Typs)
* Spezielle Datentypen, z.&nbsp;B.
* Spezielle Datentypen, z.&nbsp;B.
** <tt>[[Object Identifier|OBJECT IDENTIFIER]]</tt> (weltweit eindeutige Kennung)
** <span style="font-family:monospace;">[[Object Identifier|OBJECT IDENTIFIER]]</span> (weltweit eindeutige Kennung)


== Normen und Standards ==
== Normen und Standards ==
ASN.1 hat eine lange Historie mit unterschiedlichen Vorläufern und Veröffentlichungen in unterschiedlichen Organisationen.

;1. Generation:
* X.208: ersetzt durch X.680
* X.208: ersetzt durch X.680
* X.209: ersetzt durch X.690
* X.209: ersetzt durch X.690


;2. Generation:
Reihe X.680:
* X.680: Specification of Basic Notation
* X.680: Specification of Basic Notation
* X.681: Information Object Specification
* X.681: Information Object Specification
* X.682: Constraint Specification
* X.682: Constraint Specification
* X.683: Parameterization of ASN.1 Specifications
* X.683: Parameterization of ASN.1 Specifications
Reihe X.690:

* X.690: Specification of Basic Encoding Rules (BER), Canonical Encoding Rules (CER) and Distinguished Encoding Rules (DER)
* X.690: Specification of Basic Encoding Rules (BER), Canonical Encoding Rules (CER) and Distinguished Encoding Rules (DER)
* X.691: Specification of Packed Encoding Rules (PER)
* X.691: Specification of Packed Encoding Rules (PER)
* X.692: Specification of Encoding Control Notation (ECN)
* X.692: Specification of Encoding Control Notation (ECN)
* X.693: [[Extensible Markup Language|XML]] Encoding Rules
* X.693: XML Encoding Rules
* X.694: Mapping [[World Wide Web Consortium|W3C]] [[XML Schema]] Definitions into ASN.1
* X.694: Mapping W3C XML Schema Definitions into ASN.1
* X.696: Specification of Octet Encoding Rules (OER) and Canonical Octet Encoding Rules (COER)

;3. Generation:
Reihe ISO 8824:
* ISO/IEC 8824-1: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Basisnotationen.
* ISO/IEC 8824-2: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Informationsobjekten.
* ISO/IEC 8824-3: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Beschränkungen.
* ISO/IEC 8824-4: Abstrakte Syntax Notation Eins (ASN.1): Parametrierung von ASN.1 Spezifikationen.

Reihe ISO 8825:

''Hinweis: Die offiziellen deutschen Titel dieser Spezifikationen enthalten zwar das Wort ''verschlüsseln'', das ist aber nicht im Sinne der [[Kryptographie]] gemeint, sondern wie im [[Internationale statistische Klassifikation der Krankheiten und verwandter Gesundheitsprobleme|Sprachgebrauch der Mediziner]] üblich. Technisch exakt wäre hier, von [[Code|Kodierung]] zu sprechen.''

* ISO/IEC 8825-1: ASN.1 Verschlüsselungsregeln: Spezifikation von Basisverschlüsselungsregeln (BER), vorschriftsmäßigen Verschlüsselungsregeln (CER) und hervorragenden Verschlüsselungsregeln.
* ISO/IEC 8825-2: ASN.1 Verschlüsselungsregeln: Spezifikation von komprimierten Verschlüsselungsregeln (PER).
* ISO/IEC 8825-3: Kodierungsregeln für ASN.1: Spezifikation der Verschlüsselungkontrollnotation (ECN).
* ISO/IEC 8825-4: Kodierungsregeln für ASN.1: XML Kodierungsregeln (XER).
* ISO/IEC 8825-5: ASN.1 Kodierungsregeln: Abbildung der W3C XML Schema-Definitionen auf ASN.1.
* ISO/IEC 8825-6: ASN.1 encoding rules: Registration and application of PER encoding instructions.
* ISO/IEC 8825-7: ASN.1 encoding rules - Part 7: Specification of Octet Encoding Rules (OER).


;Sonstige:
* {{RFC-Internet |Autor=S. Legg |RFC=3641 |Titel=Generic String Encoding Rules (GSER) for ASN.1 Types |Datum=2003-10 |Kommentar=veraltet}}
* {{RFC-Internet |Autor=S. Legg |RFC=4792 |Titel=Encoding Instructions for the Generic String Encoding Rules (GSER) |Datum=2007-01}}

== Literatur ==
* {{Literatur
|Autor=Walter Gora
|Titel=ASN.1 – Abstract Syntax Notation One
|Auflage=Nachdruck der 3. Auflage
|Verlag=Fossil-Verlag
|Ort=Köln
|Datum=1998
|ISBN=3-931959-18-X
|Kapitel=Edition Netze}}


== Weblinks ==
== Weblinks ==
* [http://www.itu.int/ ITU]
* [https://www.itu.int/rec/T-REC-X.680/ ASN.1 Standard]
* [http://www.itu.int/ITU-T/studygroups/com17/languages/ ASN.1 Standard]
* [https://www.itu.int/en/ITU-T/asn1/Pages/asn1_project.aspx ASN.1 Project]
* [http://www.oss.com/asn1/dubuisson.html ASN.1 Free Reference Book]
* [http://www.asn1.org/ ASN.1 Consortium]
* [http://www.obj-sys.com/asn1tutorial/asn1only.html ASN 1 Tutorial]
* [http://www.openmuc.org/index.php?id=20 jASN1], Offene ASN.1-BER-Java-Bibliothek des Fraunhofer ISE in Freiburg
* [http://www.openasn1.org openASN.1] Ein Open Source ASN.1-Toolkit für [[Java (Programmiersprache)|Java]]
* [http://lionet.info/asn1c/ Free, open source ASN.1 compiler]
* RFC 3641 (Generic String Encoding Rules (GSER) for ASN.1 Types)


[[Kategorie:Norm]]
[[Kategorie:Norm]]
Zeile 75: Zeile 113:
[[Kategorie:Mobilfunk]]
[[Kategorie:Mobilfunk]]
[[Kategorie:Beschreibungssprache]]
[[Kategorie:Beschreibungssprache]]
[[Kategorie:Datenserialisierungformat]]

Aktuelle Version vom 29. September 2023, 20:11 Uhr

Die Abstract Syntax Notation One (ASN.1; deutsch Abstrakte Syntaxnotation Eins) ist eine Beschreibungssprache zur Definition von Datenstrukturen sowie Festlegungen zur Umsetzung von Datenstrukturen und Elementen in ein netzeinheitliches Format. Sie ist gemeinsamer Standard der ITU-T (International Telecommunication Union – Telecommunication Standardization Sector) und der ISO (Internationale Organisation für Normung).

Das Wort Abstract im Namen bedeutet, dass zwar die (abstrakte) Struktur der Daten festgelegt wird, nicht aber die (konkrete) Schreibweise, also wie die einzelnen Bits über die Leitung geschickt oder in Dateien gespeichert werden. Durch diese Trennung zwischen Inhalt und Form ist es möglich, je nach Verwendungszweck eine dafür geeignete Schreibweise (Kodierung) zu verwenden.

Das Wort Syntax im Namen bedeutet, dass diese Notation nur festlegt, welche Form die Daten haben. Sie legt jedoch nicht fest, wie diese Daten interpretiert werden. So kann mit ASN.1 zum Beispiel eine „Folge zweier Zahlen, nämlich 7 und 13“ beschrieben werden. Was diese Zahlen inhaltlich bedeuten, wird jedoch nicht von ASN.1 festgelegt, sondern von der Anwendung, die ASN.1 verwendet.

Die Notation ist in den ITU-T-Standards X.680ff definiert. Die zugehörigen Standards X.690ff definieren verschiedene Encoding Rules (Kodierungsregeln), wie die ASN.1-Datenwerte auf Bit-Ebene kodiert werden. Mit Hilfe von ASN.1 und einer gemeinsamen Kodierungsregel können Systeme mit unterschiedlichen internen Datendarstellungen Nachrichten austauschen.

ASN.1 ist eine verbreitete Möglichkeit, die Nachrichtenelemente von Protokollen des OSI-Modells eindeutig zu beschreiben, und wird von OSI-konformen Techniken wie X.500 und X.509, aber auch von Internetprotokollen wie SNMP oder LDAP verwendet. Breite Anwendung findet ASN.1 auch im Telekommunikationsbereich, z. B. bei den Standards GSM für die Abrechnung von Roaminggesprächen in TAP3-Dateien und UMTS.

Meist werden in ASN.1 spezifizierte Daten mit den einfach zu handhabenden Basic Encoding Rules (BER) kodiert. In Bereichen, bei denen eine platzsparende Kodierung erwünscht ist (zum Beispiel Mobilfunk), werden die Packed Encoding Rules (PER) bevorzugt. Weiterhin existieren die injektiven Canonical Encoding Rules (CER) und Distinguished Encoding Rules (DER), wobei letztere weiter verbreitet sind. Die Distinguished Encoding Rules sind eine Untermenge der BER und sind eine Codierung von ASN.1-Datenbeschreibungen, die auf Bitebene völlig eindeutig ist. Es gibt in den DER also im Unterschied zu den BER für jeden ASN.1-Wert nur eine mögliche Codierung. Damit eignen sie sich für Fälle, in denen ASN.1-Daten digital signiert werden müssen oder plattformübergreifend ausgetauscht werden sollen, beispielsweise in digitalen Zertifikaten (siehe X.509).

Syntax und Semantik

[Bearbeiten | Quelltext bearbeiten]

ASN.1 wird in einer BNF-ähnlichen Darstellung beschrieben, z. B.:

Record ::= SEQUENCE {
  kopf Header,
  daten Data OPTIONAL
}
Header ::= IA5String
Data ::= SET OF INTEGER

Im nächsten Beispiel wird ein Modul vereinbart. Es ist möglich, dieses Modul auch mittels eines Object Identifiers zu finden. Dies geschieht, indem man dem Modulnamen eine Objektreferenz (Object Reference) anfügt, z. B.:

Modul-name {joint-iso-itu-t(2) example(999)} DEFINITIONS ::= 
BEGIN
  Daten-struktur ::= SEQUENCE {
    teil INTEGER,
    fragment IA5String
  }
END

Vor dem Begriff DEFINITIONS wird mittels der geschweiften Klammern eine Objektreferenz, also eine ID angelegt. Die Objektreferenz verweist auf die Stelle in einem Baum von Referenzen bzw. Vereinbarungen, an der das richtige Objekt zu finden ist. Die ID aus diesem Beispiel verweist auf die erste Wurzel in der ersten Ebene der Verweisstruktur. Module in der oben dargestellten Form sind nötig, um eine Vereinbarung zu treffen, wie Daten übertragen werden sollen. Daten, die wie im obigen Beispiel definiert sind, werden wie folgt übertragen: { 2, "Teil2" }.

ASN.1 kennt dazu u. a.

  • Elementare Typen, z. B.
    • BIT STRING (binäre Zeichenfolge)
    • BOOLEAN
    • IA5String (nach IA5-Tabelle kodierte Zeichenfolge, siehe ISO 646)
    • INTEGER
  • Zusammengesetzte Typen, z. B.
    • CHOICE (Summentyp)
    • SEQUENCE (geordnete Abfolge verschiedener Typen)
    • SEQUENCE OF <Typ> (geordnete Abfolge gleichen Typs)
    • SET (ungeordnete Abfolge verschiedener Typen)
    • SET OF <Typ> (ungeordnete Abfolge gleichen Typs)
  • Spezielle Datentypen, z. B.

Normen und Standards

[Bearbeiten | Quelltext bearbeiten]

ASN.1 hat eine lange Historie mit unterschiedlichen Vorläufern und Veröffentlichungen in unterschiedlichen Organisationen.

1. Generation
  • X.208: ersetzt durch X.680
  • X.209: ersetzt durch X.690
2. Generation

Reihe X.680:

  • X.680: Specification of Basic Notation
  • X.681: Information Object Specification
  • X.682: Constraint Specification
  • X.683: Parameterization of ASN.1 Specifications

Reihe X.690:

  • X.690: Specification of Basic Encoding Rules (BER), Canonical Encoding Rules (CER) and Distinguished Encoding Rules (DER)
  • X.691: Specification of Packed Encoding Rules (PER)
  • X.692: Specification of Encoding Control Notation (ECN)
  • X.693: XML Encoding Rules
  • X.694: Mapping W3C XML Schema Definitions into ASN.1
  • X.696: Specification of Octet Encoding Rules (OER) and Canonical Octet Encoding Rules (COER)
3. Generation

Reihe ISO 8824:

  • ISO/IEC 8824-1: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Basisnotationen.
  • ISO/IEC 8824-2: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Informationsobjekten.
  • ISO/IEC 8824-3: Abstrakte Syntax Notation Eins (ASN.1): Spezifikation von Beschränkungen.
  • ISO/IEC 8824-4: Abstrakte Syntax Notation Eins (ASN.1): Parametrierung von ASN.1 Spezifikationen.

Reihe ISO 8825:

Hinweis: Die offiziellen deutschen Titel dieser Spezifikationen enthalten zwar das Wort verschlüsseln, das ist aber nicht im Sinne der Kryptographie gemeint, sondern wie im Sprachgebrauch der Mediziner üblich. Technisch exakt wäre hier, von Kodierung zu sprechen.

  • ISO/IEC 8825-1: ASN.1 Verschlüsselungsregeln: Spezifikation von Basisverschlüsselungsregeln (BER), vorschriftsmäßigen Verschlüsselungsregeln (CER) und hervorragenden Verschlüsselungsregeln.
  • ISO/IEC 8825-2: ASN.1 Verschlüsselungsregeln: Spezifikation von komprimierten Verschlüsselungsregeln (PER).
  • ISO/IEC 8825-3: Kodierungsregeln für ASN.1: Spezifikation der Verschlüsselungkontrollnotation (ECN).
  • ISO/IEC 8825-4: Kodierungsregeln für ASN.1: XML Kodierungsregeln (XER).
  • ISO/IEC 8825-5: ASN.1 Kodierungsregeln: Abbildung der W3C XML Schema-Definitionen auf ASN.1.
  • ISO/IEC 8825-6: ASN.1 encoding rules: Registration and application of PER encoding instructions.
  • ISO/IEC 8825-7: ASN.1 encoding rules - Part 7: Specification of Octet Encoding Rules (OER).


Sonstige
  • S. Legg: RFC: 3641 – Generic String Encoding Rules (GSER) for ASN.1 Types. Oktober 2003 (veraltet, englisch).
  • S. Legg: RFC: 4792 – Encoding Instructions for the Generic String Encoding Rules (GSER). Januar 2007 (englisch).
  • Walter Gora: ASN.1 – Abstract Syntax Notation One. Nachdruck der 3. Auflage. Fossil-Verlag, Köln 1998, ISBN 3-931959-18-X, Edition Netze.