在为我的站点编写应用程序接口服务时,我意识到String.split()
不会持续很长时间,于是决定试试正则表达式。我差不多做完了,但我找不到最后一块了。这是我想要做的:
URL表示函数调用:
/api/SECTION/FUNCTION/[PARAMS]
最后这部分,包括斜杠,是可选的。有些函数在不接收任何参数的情况下显示JSON应答。示例:/api/sounds/getAllSoundpacks
打印可用声包的列表。不过,/api/sounds/getPack/8Bit
会打印详细信息。
下面是我尝试过的表达式:
req.url.match(/\/(.*)\/(.*)\/?(.*)/);
我遗漏了什么使最后一部分成为可选的-或者完整地捕获它?
发布于 2014-09-14 12:33:17
这将捕获URL中FUNCTION/之后的所有内容,独立于任何其他/ after FUNCTION/的外观:
FUNCTION\/(.+)$
如果没有part after FUNCTION,则RegExp将不匹配。
发布于 2014-09-14 12:54:56
这个正则表达式应该通过将最后一个斜杠和后面的部分设置为可选来工作:
/^\/[^/]*\/[^/]*(?:\/.*)?$/
这与所有这些字符串都匹配:
/api/SECTION/FUNCTION/abc
/api/SECTION
/api/SECTION/
/api/SECTION/FUNCTION
发布于 2014-09-20 12:44:43
你的模式/(.*)/(.*)/?(.*)
几乎是正确的,只是有点太短了-它允许2到3个斜杠,但你想接受任何有3到4个斜杠的东西。如果你想捕获最后一个(可选的)斜杠和它后面的任何文本作为一个整体,你只需要在这个部分周围创建一个组,并使其成为可选的:
/.*/.*/.*(?:/.+)?
应该能行得通。
Demo. (该模式看起来有所不同,因为启用了多行模式,但它仍然有效。它也有一点“更好”,因为它不会像“/”那样匹配垃圾。)
https://stackoverflow.com/questions/25832886
复制相似问题