200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > php正则 网址 php正则表达式匹配URL中的域名

php正则 网址 php正则表达式匹配URL中的域名

时间:2024-04-03 02:34:18

相关推荐

php正则 网址 php正则表达式匹配URL中的域名

在PHP的官网上看到parse_url()函数的替代,其结果和parse_url()函数差不多,是使用正则实现的,看到好就转过来。

原文请参考:/parse_url#104958

这里就不翻译了,它可以解析URI。

URI 是 Web上可用的每种资源 - HTML文档、图像、视频片段、程序等 - 由一个通用资源标志符(Uniform Resource Identifier, 简称"URI")进行定位。

对就分组:

^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?

12 3 4 5 6 7 8 9

PHP 测试:

复制代码 代码如下:

$search = '~^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?~i';

$url = '/pub/ietf/uri/#Related';

$url = trim($url);

preg_match_all($search, $url ,$rr);

printf("

输出URL数据为:

%s

\n",var_export( $rr ,TRUE));

/*

各分组如下

$1 = http:

$2 = http

$3 = //

$4 =

$5 = /pub/ietf/uri/

$6 =

$7 =

$8 = #Related

$9 = Related

*/

?>

这里提供另一个简洁的代码:

复制代码 代码如下:

// 从 URL 中取得主机名

preg_match("/^(http:\/\/)?([^\/]+)/i", "http:///index.html", $matches);

$host = $matches[2];

// 从主机名中取得后面两段

preg_match("/[^\.\/]+\.[^\.\/]+$/", $host, $matches);

echo "domain name is: {$matches[0]}\n";

?>

执行后输出:domain name is:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。