php 截取url中后面的参数,php解析url并得到url中的参数及获取url参数的四种方式...

本文介绍了PHP中解析URL获取参数的四种方法:$_SERVER['QUERY_STRING']、pathinfo()、parse_url()和basename(),以及正则匹配的方式。通过实例详细展示了每种方法的使用和结果,帮助开发者在不同场景下选择合适的URL参数获取方式。
摘要由CSDN通过智能技术生成

下面一段代码是php解析url并得到url中的参数,代码如下所示:

$url = 'http://www.baidu.com/index.php?m=content&c=index&a=lists&catid=6&area=0&author=0&h=0&region=0&s=1&page=1';

$arr = parse_url($url);

var_dump($arr);

$arr_query = convertUrlQuery($arr['query']);

var_dump($arr_query);

var_dump(getUrlQuery($arr_query));

/**

* 将字符串参数变为数组

* @param $query

* @return array array (size=10)

'm' => string 'content' (length=7)

'c' => string 'index' (length=5)

'a' => string 'lists' (length=5)

'catid' => string '6' (length=1)

'area' => string '0' (length=1)

'author' => string '0' (length=1)

'h' => string '0' (length=1)

'region' => string '0' (length=1)

's' => string '1' (length=1)

'page' => string '1' (length=1)

*/

function convertUrlQuery($query)

{

$queryParts = explode('&', $query);

$params = array();

foreach ($queryParts as $param) {

$item = explode('=', $param);

$params[$item[0]] = $item[1];

}

return $params;

}

/**

* 将参数变为字符串

* @param $array_query

* @return string string 'm=content&c=index&a=lists&catid=6&area=0&author=0&h=0&region=0&s=1&page=1' (length=73)

*/

function getUrlQuery($array_query)

{

$tmp = array();

foreach($array_query as $k=>$param)

{

$tmp[] = $k.'='.$param;

}

$params = implode('&',$tmp);

return $params;

}

下面通过四种实例给大家介绍php url 参数获取方式。

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

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

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

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

第二种、利用pathinfo内置函数

代码如下:

$test = pathinfo("http://localhost/index.php");

print_r($test);

/*

结果如下

Array

(

[dirname] => http://localhost //url的路径

[basename] => index.php //完整文件名

[extension] => php //文件名后缀

[filename] => index //文件名

)

*/

?>

第三种、利用parse_url内置函数

代码如下:

$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内置函数

代码如下:

$test = basename("http://localhost/index.php?name=tank&sex=1#top");

echo $test;

/*

结果如下

index.php?name=tank&sex=1#top

*/

?>

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

下面拓展实践下正则处理方式:

代码如下:

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

)

)

*/

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用正则表达式来截取 URL 参数。 以下代码示例可以截取当前页面 URL 参数: ```javascript function getQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"); var r = window.location.search.substr(1).match(reg); if (r != null) { return decodeURI(r[2]); } return null; } ``` 其,`name` 参数为需要截取参数名。 例如,当前页面 URL 为 `https://www.example.com/?id=123&name=example`,如果需要获取 `id` 参数的值,可以使用以下代码: ```javascript var id = getQueryString('id'); console.log(id); // 输出:123 ``` ### 回答2: JavaScript可以通过URL的查询字符串来获取参数。 首先,可以通过`window.location.search`获取URL的查询字符串部分,例如:`?key1=value1&key2=value2`。 接下来,可以使用正则表达式来解析查询字符串并提取参数。例如,可以使用`/[\?\&]([^=]+)\=([^&]+)/g`正则表达式来匹配查询字符串的每个参数和对应的值。 一种常见的方法是使用`window.location.search`和正则表达式来创建一个参数对象,该对象包含所有的参数和对应的值。 下面是一个示例代码: ```javascript function getUrlParams() { var params = {}; var queryString = window.location.search.substring(1); var regex = /[\?\&]([^=]+)\=([^&]+)/g; var match; while (match = regex.exec(queryString)) { var key = decodeURIComponent(match[1]); var value = decodeURIComponent(match[2]); params[key] = value; } return params; } // 示例URL:http://example.com/?key1=value1&key2=value2 var params = getUrlParams(); console.log(params.key1); // 输出:value1 console.log(params.key2); // 输出:value2 ``` 在上面的示例,`getUrlParams`函数将URL的查询字符串解析为一个参数对象,并返回该对象。通过`params.key1`和`params.key2`可以获取到对应的值。 ### 回答3: 在JavaScript,可以通过以下步骤从URL截取参数: 1. 获取当前页面的URL: ```javascript var url = window.location.href; ``` 2. 使用URL的search属性获取查询字符串部分: ```javascript var queryString = url.split('?')[1]; ``` 3. 将查询字符串分割成参数的键值对数组: ```javascript var params = queryString.split('&'); ``` 4. 使用循环遍历参数数组,将参数的键值对分离出来: ```javascript var parameters = {}; for (var i = 0; i < params.length; i++) { var pair = params[i].split('='); var key = decodeURIComponent(pair[0]); var value = decodeURIComponent(pair[1]); parameters[key] = value; } ``` 现在,我们可以通过访问parameters对象的属性来获取相应的参数值。例如,如果URL是`https://example.com/?name=John&age=25`,我们可以使用`parameters.name`来获取"name"参数的值,使用`parameters.age`来获取"age"参数的值。 注意,以上代码假设URL只有一个查询字符串,如果URL有多个查询字符串,建议使用正则表达式或辅助函数来提取参数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值