ASN.1编码学习笔记一

1.什么是ASN.1(抽象语法记法一)?

        ASN.1是ITU-T的一个标准集,它用来编码及表示通用数据类型,这些数据类型有可打印串值,八位位组串值,位串值,整数值以及用可移值方式组合而成的其他类型序列值.简单的说,ASN.1指定了以何种方式对非平凡的数据类型进行编码,以便其他任何平台及第三方工具都能够解释其内容.比如,字母a在一些平台以ASCII编码为十进制数值97,而在其他非ASCII平台上,可能会是另外的编码.而ASN.1指定了一种编码方式,在任何平台上,字母a的编码都是统一的.

 

 

2.ASN.1语法.

        ASN.1语法遵循传统的巴科斯范式BNF风格.最基本的表达式如: Name ::= type . 表示为定义某个名称为Name的元素,它的类型为type. 例如: MyName ::= IA5String . 表示为定义了一个名为MyName的元素或变量,其类型为ASN.1类型IA5String (类似于ASCII字符串).

 

2.1 ASN.1显式值(Explict Value).

  有些时候,我们需要定义一种ASN.1类型,它的子集元素包含预定义值. Name ::= type (Explict Value) .  显式值(Explict Value).必须是ASN.1类型允许选择的值,而且也必须是元素所允许的值.例: MyName ::= IA5String (Tom) 表示MyName是字符串Tom的IA5String编码. 又例如: MyName ::= IA5String(Tom|Joe) 表示字符串的值既可以是Tom, 也可以是Joe.

        这种语法的使用是为了扩展确定的解码器.例:

        PublicKey ::= SEQUENCE {

            KeyType       BOOLEAN(0),

            Modulus        INTEGER,

            PubExponent INTEGER

        }

 

        PrivateKey ::= SEQUENCE {

            KeyType       BOOLEAN(1)

            Modulus         INTEGER,

            PubExponent  INTEGER,

            PrivateExponent INTEGER

          }

 

2.2 ASN.1容器(container)

        容器是值一个包含了其他相同或者不同类型元素的数据类型(例如序列值SEQUENCE或集合值SET类型).目的是为了组合一些复杂的数据类型集.ASN.1规范定义了4种容器类型:序列,单一序列(SEQUENCE OF),集合和单一集合(SET OF).虽然它们意义不同,但是语法是一样的.

        Name ::= Container {Name Type [ Name Type...]}   方括号中的内容和容器的元素个数都是可选项.还可以进行嵌套定义.

例:

  UserRecord ::= SEQUENCE {

           Name   SEQUENCE {

               First IA5String,

               Last  IA5String

            },

           DoB     UTCTIME

        }

将其粗略的翻译成C语言中的结构如下:

  struct UserRecord {

           struct Name {

             char *First,

             char *Last

           };

          time_t DoB;

        }

将其粗略的翻译成Object Pascal语言中的记录如下(Object Pascal不支持嵌套记录):

       Type

            Name = record

              First : String;

              Last  : String;

            end;

            UserRecord = record

              aName : Name;

              DoB    : DateTime;

            end;

 

2.3ASN.1修改器

        ASN.1定义了各种修改器,如可选(OPTIONAL),默认(DEFAULT),和选择(CHOICE). 他们可以改变表达式的声明.典型地用于定义一种要求编码灵活,而定义又不繁琐的类型.

       <1>.可选(OPTIONAL)。顾名思义,其表示改变一个元素以便在编码时它的类型是可选择的.即编码器可以忽略这个元素,解码器不能假设它将出现.但当邻接的两个元素具有相同的类型时,会给解码器带来一些问题.

        定义: Name ::= Type OPTIONAL

  例如:

      Float ::= SEQUENCE {

                                         Exponent     INTEGER OPTIONAL,

                                         Mantissa     INTEGER,

                                         Sign             BOOLEAN

                       }

         当解码器读取这个结构时,在它看来第一个整数(INTEGER)可能是Exponent,也有可能认为是Mantissa. 一般建议不使用这种方式定义结构.

  <2>.默认(DEFAULT).默认修改器允许容器包含默认值.如果待编码的数据值等同于它的默认值,那么它将在发送的数据流中被忽略.例如:

      Command ::= SEQUENCE {

                                         Token         IA5String(NOP) DEFAULT,

                                         Parameter   INTEGER

                       }

         如果编码器把Token看成是代表字符串NOP,那么序列将按照定义的那样编码为:

                      Command ::= SEQUENCE {

                                        Parameter    INTEGER

                      }

        <3>.选择(CHOICE). 选择修改器允许一个元素在给定的实例中可以有多个可能值.实质上说,解码器将尝试所有期望的解码算法,直到有一个类型符合为止.当一个复杂的容器中包含其他容器时,时候选择器就十分有用了.例如:

      UserKey ::= SEQUENCE {

                                       Name             IA5String,

                                       StartDate       UTCTIME,

                                       Expire            UTCTIME,

                                       KeyData        CHOICE {

                                              ECCKey        ECCKeyType,

                                              RSAKey        RSAKeyType

                                       }

                        }

         上例简单的允许ECC也允许RSA密钥的公钥证书.

 

 

 

 

  • 0
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
ASN.1(Abstract Syntax Notation One)是一种用于描述数据结构和编码规则的标准化方法。ASN.1编码规则国标是指中国制定的ASN.1编码规则的国家标准。 ASN.1编码规则国标包括两个方面的内容:ASN.1数据结构的定义和ASN.1数据的编码规则。 ASN.1数据结构的定义是使用一种形式化的语言来描述数据的结构和类型。它定义了一些基本的数据类型,如整数、字符串、对象标识符等,并允许用户根据需要定义复杂的数据类型,例如序列、集合、选择等。这样,可以按照预先定义好的规则来定义和描述数据的结构,使得不同系统之间可以相互理解和交换数据。 ASN.1数据的编码规则规定了如何将ASN.1数据转换成二进制格式进行传输。常用的ASN.1编码规则有BER、DER、CER等。这些编码规则根据对数据体积和传输效率的要求,定义了不同的编码方式和规则,例如使用可变长度编码或固定长度编码,使用标记位表示数据类型等。ASN.1编码规则国标就是在这些基本的ASN.1编码规则的基础上,针对中国国情和实际需求,进行了一些适应性的修改和补充。 ASN.1编码规则国标的制定是为了提高通信系统的互操作性和数据交换的安全性。通过遵循ASN.1编码规则国标,不同厂家和不同系统可以更加方便地进行数据的交换和共享,避免了不同系统之间的兼容性问题和数据解析错误的风险。同时,ASN.1编码规则国标还可以提供一定的安全机制,比如对数据进行签名和加密,保证数据在传输过程中的安全性。 总之,ASN.1编码规则国标是一种在中国制定的用于描述数据结构和编码规则的国家标准。它为不同系统之间的数据交换提供了统一的标准和规范,提高了通信系统的互操作性和数据交换的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值