PHP解析URL及parse_url、parse_str、explode、implode函数说明

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

首先看一下解析任意URL的代码:

(1)获取协议类型;例如参考链接中的:http

(2)获取主机地址;例如参考链接中的:my.oschina.net

(3)获取当前页面在服务器的路径;例如参考链接中的:liuhui1990/blog/42232

(4)获取URL中的参数;

复制代码
 1 <?php
 2 //例举一个URL格式的字符串:
 3 $str = 'http://test.com/testdir/index.php?param1=10&param2=20&param3=30&param4=40&param5=50&param6=60';
 4  
 5 //1.0 用parse_url解析URL,此处是$str
 6 $arr = parse_url($str);
 7 var_dump($arr);
 8  
 9  
10 //2.0 将URL中的参数取出来放到数组里
11 $arr_query = convertUrlQuery($arr['query']);
12 var_dump($arr_query);
13  
14  
15 //3.0 将 参数数组 再变回 字符串形式的参数格式
16 var_dump(getUrlQuery($arr_query));
17  
18  
19 /** 
20  * Returns the url query as associative array 
21  * 
22  * @param    string    query 
23  * @return    array    params 
24  */
25 function convertUrlQuery($query)
26 { 
27     $queryParts = explode('&', $query); 
28      
29     $params = array(); 
30     foreach ($queryParts as $param) 
31     { 
32         $item = explode('=', $param); 
33         $params[$item[0]] = $item[1]; 
34     } 
35      
36     return $params; 
37 }
38  
39 function getUrlQuery($array_query)
40 {
41     $tmp = array();
42     foreach($array_query as $k=>$param)
43     {
44         $tmp[] = $k.'='.$param;
45     }
46     $params = implode('&',$tmp);
47     return $params;
48 }
复制代码

上边代码的执行结果:

下面看一下其中涉及的函数:

parse_url():解析URL

函数原型为   mixed parse_url ( string  u r l [ , i n t component = -1 ] )

这个函数可以解析一个string $url并返回一个关联数组或string或int,包含URL中出现的各种组成部分。

component用来指定获取URL中的哪部分string,可以是

PHP_URL_SCHEME(如http),   PHP_URL_PORT(返回integer值),   PHP_URL_USER,

PHP_URL_PASS,         PHP_URL_PATH,   PHP_URL_QUERY(问号?之后),

PHP_URL_FRAGMENT(散列符号#之后)中的任何一个,然后会返回string。如果省略的话,那就返回关联数组array。

此外,还有一个函数parse_str()需要介绍一下:

函数原型为   parse_str(string ,array)

这个函数可以把Query String中的变量解析到array中,array可以缺省,但是会覆盖原变量;

注意:php.ini中的magic_quotes_gpc设置影响该函数的输出,如果已经启用了,那么在parse_str()解析之前,变量会被addslashes()转换。

用法示例:

复制代码
1 <?php
2 $url='http://www.phpernote.com/ad.php?id=325&action=index&page=3';
3 $urlarr=parse_url($url);
4 parse_str($urlarr['query'],$parr);
5 print_r($urlarr);
6 print_r($parr);
复制代码

输出结果:

复制代码
 1 Array
 2 (
 3     [scheme] => http
 4     [host] => www.phpernote.com
 5     [path] => /ad.php
 6     [query] => id=325&action=index&page=3
 7 )
 8 Array
 9 (
10     [id] => 325
11     [action] => index
12     [page] => 3
13 )
复制代码

explode():把字符串分割为数组。

函数原型:explode(separator,string,limit)

参数说明:

separator 必需。规定在哪里分割字符串。

string 必需。要分割的字符串。

limit 可选。规定所返回的数组元素的最大数目。

函数说明:

本函数返回由字符串组成的数组,其中的每个元素都是由 separator 作为边界点分割出来的子字符串。

separator 参数不能是空字符串。如果 separator 为空字符串(""),explode() 将返回 FALSE。如果 separator 所包含的值在 string 中找不到,那么 explode() 将返回包含 string 中单个元素的数组。

如果设置了 limit 参数,则返回的数组包含最多 limit 个元素,而最后那个元素将包含 string 的剩余部分。

如果 limit 参数是负数,则返回除了最后的 -limit 个元素外的所有元素。此特性是 PHP 5.1.0 中新增的。

implode():把数组元素组合为一个字符串。

函数原型:implode(separator,array)

参数说明:

separator 可选(不建议不填写)。规定数组元素之间放置的内容。默认是 ""(空字符串)。

array 必需。要结合为字符串的数组。


本文转自ZH奶酪博客园博客,原文链接:http://www.cnblogs.com/CheeseZH/p/4515579.html,如需转载请自行联系原作者

相关文章
|
18天前
|
运维 数据库连接 PHP
PHP中的异常处理机制深度解析####
本文深入探讨了PHP中异常处理机制的工作原理,通过实例分析展示了如何有效地使用try-catch语句来捕获和处理运行时错误。我们将从基础概念出发,逐步深入到高级应用技巧,旨在帮助开发者更好地理解和利用这一强大的工具,以提高代码的稳定性和可维护性。 ####
|
18天前
|
PHP 开发者 UED
PHP中的异常处理机制解析####
本文深入探讨了PHP中的异常处理机制,通过实例解析try-catch语句的用法,并对比传统错误处理方式,揭示其在提升代码健壮性与可维护性方面的优势。文章还简要介绍了自定义异常类的创建及其应用场景,为开发者提供实用的技术参考。 ####
|
16天前
|
PHP 开发者 容器
PHP命名空间深度解析及其最佳实践####
本文深入探讨了PHP中引入命名空间的重要性与实用性,通过实例讲解了如何定义、使用及别名化命名空间,旨在帮助开发者有效避免代码冲突,提升项目的模块化与可维护性。同时,文章还涉及了PHP-FIG标准,引导读者遵循最佳实践,优化代码结构,促进团队协作效率。 ####
24 1
|
19天前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
18 1
|
22天前
|
编译器 PHP 开发者
PHP 8新特性解析与实战应用####
随着PHP 8的发布,这一经典编程语言迎来了诸多令人瞩目的新特性和性能优化。本文将深入探讨PHP 8中的几个关键新功能,包括命名参数、JIT编译器、新的字符串处理函数以及错误处理改进等。通过实际代码示例,展示如何在现有项目中有效利用这些新特性来提升代码的可读性、维护性和执行效率。无论你是PHP新手还是经验丰富的开发者,本文都将为你提供实用的技术洞察和最佳实践指导。 ####
27 1
|
26天前
|
数据库连接 PHP 开发者
PHP中的异常处理机制深度解析####
本文深入探讨了PHP中异常处理的核心概念、使用场景及最佳实践,旨在帮助开发者更高效地管理和响应运行时错误。通过实例演示和理论分析,揭示try-catch块的运作原理,以及如何自定义异常类以增强代码的可读性和可维护性。文章还对比了传统错误处理方式与异常处理的优势,为读者提供了在复杂项目中实施健壮错误管理策略的指导。 ####
|
25天前
|
数据采集 JavaScript 网络安全
为什么PHP爬虫抓取失败?解析cURL常见错误原因
豆瓣电影评分是电影市场的重要参考,通过网络爬虫技术可以高效采集评分数据,帮助电影制作和发行方优化策略。本文介绍使用PHP cURL库和代理IP技术抓取豆瓣电影评分的方法,解决反爬机制、网络设置和数据解析等问题,提供详细代码示例和优化建议。
为什么PHP爬虫抓取失败?解析cURL常见错误原因
|
1月前
|
PHP 开发者
PHP 7新特性深度解析
【10月更文挑战第40天】随着PHP 7的发布,这个广泛使用的语言带来了许多令人兴奋的新特性和性能改进。本文将深入探讨PHP 7的主要变化,包括类型声明、错误处理机制、性能优化等方面,帮助开发者更好地理解和应用这些新特性。
33 4
|
1月前
|
关系型数据库 MySQL 数据库连接
PHP内置函数
PHP内置函数
25 5
|
1月前
|
API PHP 数据库
PHP中的异常处理机制深度解析与最佳实践####
本文深入探讨了PHP中异常处理机制的核心概念、工作原理及其在现代Web开发中的应用。通过剖析try-catch结构、自定义异常类及异常的继承体系,揭示了如何高效地捕获、处理并管理运行时错误,以提升应用的稳定性和用户体验。文章还结合实例,分享了在实际项目中实施异常处理的最佳实践,帮助开发者构建更加健壮的PHP应用程序。 ####

推荐镜像

更多
下一篇
DataWorks