① parse_url参见
在php中,有几个内置函数用于处理和解析文件或路径的相关信息。让我们逐个了解一下它们的功能。
首先,pathinfo() 函数是一个非常实用的工具,它能够分解一个路径,返回路径中的各个组成部分。这个函数会返回一个关联数组,包括路径的目录部分、文件名部分以及可能的扩展名等信息。这对于需要处理文件路径的场景非常有用。
另一个相关的函数是 parse_str(),它的作用是解析一个字符串,将其解析为变量。这个函数通常用于处理URL查询字符串或HTTP POST数据,将其中的键值对转换为PHP变量,方便进一步的操作和存储。
对于单独获取路径中的目录部分,可以使用 dirname() 函数。它接收一个路径作为参数,返回的是路径中从根目录到文件或目录名的完整部分,不包括文件名。这对于需要提取文件目录路径时非常实用。
最后,如果你只需要文件名部分,basename() 函数则是你的选择。它同样接收一个路径,返回的是路径的最后一个部分,即文件名,不包含路径信息。这对于处理文件名或下载链接时非常有用。
总的来说,这些函数在PHP中扮演着重要的角色,帮助开发者轻松处理和操作文件路径,提高代码的效率和可读性。
(PHP 4, PHP 5)
② php 如何实现pathinfo
PHP中的全局变量$_SERVER['PATH_INFO']是一个很有用的参数,众多的CMS系统在美化自己的URL的时候,都用到了这个参数。
对于下面这个网址:
http://www.test.com/index.php/foo/bar.html?c=index&m=search
我们可以得到 $_SERVER['PATH_INFO'] = ‘/foo/bar.html’,而此时 $_SERVER['QUERY_STRING'] = 'c=index&m=search';
通常,我们最初开始PHP程序编写的时候,都会使用诸如: http://www.test.com/index.php?c=search&m=main 这样的URL,这种URL不仅看起来非常奇怪,而且对于搜索引擎也是非常不友好的。很多搜索引擎收录的时候,都会忽略Query String之后的内容,google虽然不会忽略Query String,但是对于其他不含Query String的页面,会给于比较高的PR值。
下面是一段解析PATH_INFO的非常简单的代码:
<?php
if( !isset( $_SERVER['PATH_INFO'] ) ){
$pathinfo = 'default';
}else{
$pathinfo = explode('/', $_SERVER['PATH_INFO']);
}
if( is_array($pathinfo) AND !empty($pathinfo) ){
$page = $pathinfo[1];
}else{
$page = 'a.php';
}
require "$page.php";