语法规范的扩展巴科斯范式:ABNF


本备忘录的状态
本文档讲述了一种Internet社区的Internet标准跟踪协议,它需要进一步进行讨论和建
议以得到改进 。请参考最新版的“Internet正式协议标准”(STD1)来获得本协议的标准化程
度和状态 。本备忘录的发布不受任何限制 。
版权声明
Copyright(C)TheInternetSociety(1997).
目录
1.介绍 2
2.规则定义 2
2.1规则命名 2
2.2规则格式 3
2.3终结符值 3
2.4外部编码 4
3.操作符 4
3.1连接规则1规则2 4
3.2选择 规则1/规则2 4
3.3增式选择 规则1=/规则2 5
3.4值域选择 %c##-## 5
3.5序列组 (Rule1Rule2) 5
3.6不定循环 *Rule 5
3.7指定循环 nRule 6
3.8可选序列 [RULE] 6
3.9;注释 6
3.10操作符优先级 6
4.扩展巴克斯范式形式的扩展巴克斯范式定义 7
5.安全考虑 7
6.附录A-核心 8
6.1核心规则 8
6.2公共编码 9
7.致谢 9
8.参考 9
9.作者地址 9
10.完整版权声明 10
1.介绍
互联网技术规范经常需要定义一种格式化语法并能自由地使用作者认为是有用的任何符
号 。多年来,巴克斯范式(BNF)的一个修订版,即扩展巴克斯范式(ABNF),已经在许多互
联网规范中流行 。该版本平衡了压缩性和简单性,具有合理的表达能力 。在早期的ARPA网
络中,每个规范都包含了自己的一个扩展巴克斯范式定义 。这样的规范包括电子邮件规范
RFC733和之后的RFC822,这些规范已经成为定义扩展巴克斯范式的公共引用 。本文档将
这些定义分离出来,以供有选择的引用 。可以预言,它也进行了一些修改和增强 。
标准巴克斯范式与扩展巴克斯范式的区别包括命名规则,循环,选择,次序独立以及值
域 。附录A(核心)提供了一组规则定义和编码,该规则定义和编码适用于某些互联网规范
的核心词法分析器 。作为一种便利,在此给出了这些规则定义和编码,另一方面,将它从本
文正文中定义的元语言中抽取出来,同时也是将它从它的形式状态中的分离出来 。
2.规则定义
2.1规则命名
一个规则的名字简而言之就是名字本身;即,一个符号序列,该符号序列以字母打头,
后跟一个字母或数字或连字符(下划线)的组合 。
注重:规则名大小写不敏感
规则名都指同一个规则 。
与原版的巴克斯范式不同,扩展巴克斯范式中的中括号(“<”,“>”)不再需要 。不过,
无论何时只要中括号有利于辨别规则名字的使用,它们都可以用来包括规则名字 。这种表示
典型地用于限制自由格式的行文中规则名字的引用,或是区分结合在字符串中的未用空格符
分割的局部规则,这样的例子,将在后边讨论循环时给出 。
2.2规则格式
一个规则是由下面的序列定义的:
name=elementscrlf
此处指规则名,指一个或多个规则名或是终结符,是行结束标
志,回车符后紧跟换行符 。等号将规则名和规则的定义分隔开 。元素构成一个或多个规则名
(和/或)值的定义的序列,这些规则名(和/或)值依照本文中定义的各种操作符,如选择
和循环,结合在一起 。
为了视觉舒适,规则定义按左对齐格式 。当一个规则需要多行时,连续行要缩进 。左对
齐和缩进是相对于扩展巴克斯范式规则首行而言的,不必与文档左边界相齐 。
2.3终结符值
规则分解成一串终结符值,有时也叫字符 。在扩展巴克斯范式中,一个字符仅仅是一个

推荐阅读