参见英文答案 >
How do I parse a URL into hostname and path in javascript?19
我正在尝试形成一个正则表达式(javascript / node.js),它将提取子域&来自任何给定网址的域部分.这就是我最终的结论:
我正在尝试形成一个正则表达式(javascript / node.js),它将提取子域&来自任何给定网址的域部分.这就是我最终的结论:
[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)
现在,我正在考虑http,https协议和排除“www”.来自URL的子域域部分的部分.我检查了表达式&它几乎可以工作.但是,这是问题:@H_404_6@
成功@H_404_6@
'http://mplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i) 'http://lplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
失败@H_404_6@
'http://play.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i) 'http://tplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
我只是使用结果数组中的第一个元素.我不明白为什么“玩”. &安培; “T播放.”不行任何人都可以在这方面帮助我吗?@H_404_6@
“/ p”和“/ t”是否对正则表达式求值程序有任何意义?@H_404_6@
是否有任何其他方式提取子域&使用正则表达式从任何给定的URL域?@H_404_6@
编辑 – @H_404_6@
例:@H_404_6@
https://play.google.com/store/apps/details?id=com.skgames.trafficracer => play.google.com@H_404_6@
https://mail.google.com/mail/u/0/#inbox => mail.google.com@H_404_6@
解决方法
你的正则表达式似乎不正确.尝试这个正则表达式:
/^(?:https?:\/\/)?(?:[^@\n]+@)?(?:www\.)?([^:\/\n]+)/im
RegEx Demo@H_404_6@