0

当我在下面的正则表达式中检查它时,URL http://www.ftd.de/rss2无效(不冒险)<mx:RegExValidator>

<mx:RegExpValidator id="validatorURL" required="true" enabled="true"
    source="{inputURL}" property="text" triggerEvent="focusOut"
    expression="{resourceManager.getString('resources','general.urlRegExp')}"
    flags="i" />

只要 URL 不以数字结尾,这个带有以下 RegEx 的 RegExValidator 就可以正确验证 URL 。任何其他有效的 URL 似乎都是有效的。

这是为什么?弹性错误?


正则表达式

我使用Diego Perini的这个 RegEx ,它在这个比较中得到了最好的结果。

^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$

RegEx 本身与上述 URL 配合得很好,它可以在我迄今为止测试过的任何非 flex 验证器中正确验证:

我用两个基于 Flex 的验证器检查了 RegEx,它们都无法验证任何URL:


我们使用 Flex SDK 4.6.0.23201。

4

3 回答 3

1

\uhhhh2 个基于 Flex 的在线测试仪似乎无法识别该序列。这可能是 Flex 正则表达式实现中的错误,也可能是测试器实现中的错误,或者可能是文档中的错误。

在使用下面的正则表达式之前,请检查原始正则表达式是否在您的程序中有效。

这是在在线测试人员上测试正则表达式的解决方法:全部替换\uhhhh\x{hhhh}. 我不确定它在实际代码中是否仍然有效。这在任何地方都没有记录,我只是从其他用户的回答中发现了这一点。

^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)(?:\.(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)*(?:\.(?:[a-z\x{00a1}-\x{ffff}]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$

RegExr 上的演示(我使用了问题链接中的测试数据)

于 2013-02-27T09:16:14.430 回答
1

nhahtdh 的回答让我再次检查了这个问题。它没有解决问题,但它为我指明了正确的方向。我将使用他回答中的 RegExp,因为从\uhhhhto的建议转换\x{hhhh}也是必要的。

编辑:解决方案

实际的问题是,当将 RegExp 作为 String 传递给 aRegExpValidator时,它必须进行双重转义。因此,如果从资源文件中加载 Pattern,它应该如下所示:

general.urlRegExp=^(?:(?:https?|ftp):\\/\\/)(?:\\S+(?::\\S*)?@)?(?:(?!10(?:\\.\\d{1,3}){3})(?!127(?:\\.\\d{1,3}){3})(?!169\\.254(?:\\.\\d{1,3}){2})(?!192\\.168(?:\\.\\d{1,3}){2})(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\x{00a1}-\\x{ffff}0-9]+-?)*[a-z\\x{00a1}-\\x{ffff}0-9]+)(?:\\.(?:[a-z\\x{00a1}-\\x{ffff}0-9]+-?)*[a-z\\x{00a1}-\\x{ffff}0-9]+)*(?:\\.(?:[a-z\\x{00a1}-\\x{ffff}]{2,})))(?::\\d{2,5})?(?:\\/[^\\s]*)?$

现在这可以直接在RegExpValidator

<mx:RegExpValidator expression="{resourceManager.getString('resources','general.urlRegExp')}" flags="gmi" />
于 2013-03-19T15:45:09.423 回答
0

您可以使用 mx.utils.URLUtil 类:

trace(URLUtil.isHttpURL( 'http://www.ftd.de/rss2')); //true

它也有助于提取 url 的不同部分。

于 2012-12-19T18:36:04.077 回答