iCal 属性参数可以/应该转义吗?

发布于 2024-09-05 11:28:37 字数 492 浏览 3 评论 0原文

具体来说,CN(通用名称)参数,例如

ORGANIZER;CN=John Doe,Eng:mailto:[电子邮件受保护]

ORGANIZER 恕我直言,RFC 对此含糊其辞。 类型 TEXT 的属性值非常清楚,但对于此参数,它只是说“参数值为文本”。无论如何,为 TEXT 类型指定的转义对于参数值来说似乎并不完整(例如“:”没有转义)。

多谢!

specifically, the CN (common name) parameter, e.g.

ORGANIZER;CN=John Doe,Eng:mailto:[email protected]

The RFC is vague on this, IMHO. It is very clear about property values of type TEXT, but for this parameter it just says "The parameter value is text". Anyways, the escaping specified for TEXT type doesn't seem complete for parameter values (e.g. ':' is not escaped).

thanks a lot!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

向日葵 2024-09-12 11:28:37

Davka,

是的,可以通过用双引号将值引起来转义参数值。如果参数值包含以下任何字符,则必须对其进行转义:

; - semicolon
: - colon
, - comma

参数值内包含双引号 " 字符是非法的,因此应将其删除(或以其他方式从参数值中删除)。

因此,对于上面的示例,正​​确的转义是这样的:

ORGANIZER;CN="John Doe,Eng":mailto:[email protected]

请注意,一旦遇到第一个(未加引号的)冒号 :,解析引擎会将其余部分视为属性值。在属性值中使用冒号 : 字符是合法的,因此在 mailto:[email protected] 不需要转义。

我们可以将该行分成几个部分:

  • ORGANIZER - 属性名称
  • <。 code>; - 参数分隔符
  • CN - 参数名称
  • = - 参数值分隔符
  • "John Doe,Eng" - 参数值
  • < code>: - 属性值分隔符
  • mailto:[电子邮件受保护] - 属性值

这里引用 RFC 5545 第 3.2 节,解释参数值何时用双引号引起来,并告诉我们双引号在参数值中是非法的:

属性参数值包含
冒号、分号或逗号
必须指定字符分隔符
作为带引号的字符串文本值。财产
参数值不得包含
DQUOTE 字符。德科特
字符用作分隔符
参数值包含
受限字符或 URI 文本。
例如:

DESCRIPTION;ALTREP="cid:[电子邮件受保护]":这
Fall'98 狂野奇才大会 - -
美国内华达州拉斯维加斯

需要注意的是,参数在技术上可以包含多个值。使用逗号来分隔这些多个值:(

来自 RFC 5545 的第 3.2.11 节:)

ATTENDEE;MEMBER="mailto:[email protected]","mailto:pr
 [email protected]":mailto:[email protected]

并非所有 iCalendar 引擎都接受所有参数的多个值,但以下参数应该允许多个值(根据 RFC):

  • MEMBER
  • DELEGATED -来自
  • 委托-致

问候,

-道格

Davka,

Yes, parameter values can be escaped by surrounding the value in double-quotes. Parameter values must be escaped if they contain any of the following characters:

; - semicolon
: - colon
, - comma

It is illegal to have a double quote " character inside parameter values, so they should be deleted (or otherwise removed from the parameter value).

So, with your above example, the correct escaping is this:

ORGANIZER;CN="John Doe,Eng":mailto:[email protected]

Note that once the first (unquoted) colon : is encountered, parsing engines treat the rest as the property value. It is legal to use the colon : character inside property values, so the colon in mailto:[email protected] doesn't need to be escaped.

We can break the line into it's parts:

  • ORGANIZER - property name
  • ; - parameter delimiter
  • CN - parameter name
  • = - parameter value delimiter
  • "John Doe,Eng" - parameter value
  • : - property value delimiter
  • mailto:[email protected] - property value

Here's a quote from RFC 5545 Section 3.2 that explains when parameter values are surrounded with double-quotes, and tells us double-quotes are illegal in parameter values:

Property parameter values that contain
the COLON, SEMICOLON, or COMMA
character separators MUST be specified
as quoted-string text values. Property
parameter values MUST NOT contain the
DQUOTE character. The DQUOTE
character is used as a delimiter for
parameter values that contain
restricted characters or URI text.
For example:

DESCRIPTION;ALTREP="cid:[email protected]":The
Fall'98 Wild Wizards Conference - -
Las Vegas\, NV\, USA

It's important to note that parameters can technically contain multiple values. A comma is used to separate these multiple values:

(from Section 3.2.11 of RFC 5545:)

ATTENDEE;MEMBER="mailto:[email protected]","mailto:pr
 [email protected]":mailto:[email protected]

Not all iCalendar engines will accept multiple values on all parameters, but the following parameters SHOULD allow multiple values (according to the RFC):

  • MEMBER
  • DELEGATED-FROM
  • DELEGATED-TO

Regards,

-Doug

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文