> php教程 > php手册 > 본문

PHP 四种URL解析处理方式的例子

WBOY
풀어 주다: 2016-05-25 16:45:51
원래의
1287명이 탐색했습니다.

在已知URL参数的情况下,我们可以根据自身情况采用$_GET来获取相应的参数信息($_GET[\'name\']);那在未知情况下如何获取到URL上的参数信息呢?

第一种:利用$_SERVER内置数组变量

相对较为原始的$_SERVER['QUERY_STRING']来获取,URL的参数,通常使用这个变量返回的会是类似这样的数据:name=tank&sex=1

如果需要包含文件名的话可以使用$_SERVER["REQUEST_URI"](返回类似:/index.php?name=tank&sex=1)

第二种:利用pathinfo内置函数

<?php
$test = pathinfo("http://localhost/index.php");
print_r($test);
/*
 结果如下 
 Array 
 ( 
 [dirname] => http://localhost //url的路径 
 [basename] => index.php  //完整文件名 
 [extension] => php  //文件名后缀 
 [filename] => index //文件名 
 ) 
*/
?>
로그인 후 복사

第三种:利用parse_url内置函数

<?php
$test = parse_url("http://localhost/index.php?name=tank&sex=1#top");
    print_r($test);
    /*
    结果如下
    Array
    (
    [scheme] => http //使用什么协议
    [host] => localhost //主机名
    [path] => /index.php //路径
    [query] => name=tank&sex=1 // 所传的参数
    [fragment] => top //后面根的锚点
    )
    */
?>
로그인 후 복사

第四种:利用basename内置函数

<?php
    $test = basename("http://localhost/index.php?name=tank&sex=1#top"); 
echo $test;
/*
结果如下
index.php?name=tank&sex=1#top
*/
?>
로그인 후 복사

另外,还有就是自己通过正则匹配的处理方式来获取需要的值了,这种方式较为精确,效率暂不考虑,下面拓展实践下正则处理方式:


<?php
preg_match_all("/(\w+=\w+)(#\w+)?/i", "http://localhost/index.php?name=tank&sex=1#top", $match);
print_r($match);
/*
结果如下
Array
(
[0] => Array
(
[0] => name=tank
[1] => sex=1#top
)
[1] => Array
(
[0] => name=tank
[1] => sex=1
)
[2] => Array
(
[0] =>
[1] => #top
)
)
*/
로그인 후 복사



文章链接:

随便收藏,请保留本文地址!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿