使用正则表达式解析URL查询参数

Parsing URL Query Parameters using regex

本文关键字:URL 查询 参数 正则表达式      更新时间:2023-09-26

我想使用regex智能地解析url查询参数。

我必须考虑的事情:1)参数可能是无序的2)只有特定的参数必须匹配

给定一个查询字符串:"?param1=test1&param2=test2&parm3=test3"我想运行javascript regex解析param1的值和param3的值。

到目前为止我想到的正则表达式是:

/(?:[?&](?:param1=([^&]*)|param3=([^&]*)|[^&]*))+$/g

这个正则表达式似乎对我来说在https://regex101.com/等网站工作得很好。

然而,当我运行下面的JS方法时,我总是得到$2的未定义,这是param1的值应该解析到的。有什么帮助或建议吗?

"?param1=test1&param2=test2&param3=test3".replace(
/(?:[?&](?:param1=([^&]*)|param3=([^&]*)|[^&]*))+$/g,
 function ($0, $1, $2, $3) { return $0 + ' ' + $1 + ' ' + $2 + ' ' + $3; });

返回$2为未定义,$3为test3。但是,如果从url查询字符串中排除param2和param3,则可以成功地将param1解析为$2。我有点困惑。

谢谢!

.*parameterName=([^&|'n|'t's]+)

使用此模式将为您在组中提供参数值。例如这个URL:https://www.youtube.com/watch?v=aiYpDDHKy18&列表= RDaiYpDDHKy18& start_radio = 1

.*list=([^&|'n|'t's]+)

将得到你:列表id: "RDaiYpDDHKy18"

.*start_radio=([^&|'n|'t's]+)

会给你1号。

如果它们的顺序是任意的,您可以使用查找来查找它们并捕获参数值。您想要的模式(用于测试字符串)是这样的:

^(?=.*param1=([^&]+)|)(?=.*param2=([^&]+)|)(?=.*param3=([^&]+)|).+$

Regex101的演示

它还将接受缺少参数的查询字符串,因为每个forward在参数/值对或空字符串上交替,在末尾使用|

您需要对希望获取的每个参数进行额外的提前查看,这是没有办法的。因为每个正则表达式都是底层的状态机,所以使用原始模式时唯一需要坚持的是给定捕获组的最新匹配。