http_build_query
生成 URL-encode 之后的请求字符串
string http_build_query(
mixed $query_data
[,string $numeric_prefix [,string $arg_separator[,int $enc_type=PHP_QUERY_RFC1738]]]
)
- 参数说明:
参数 | 说明 |
---|---|
query_data | 可以是数组或包含属性的对象。 一个query_data数组可以是简单的一维结构,也可以是由数组组成的数组(其依次可以包含其它数组)。 如果query_data是一个对象,只有 public 的属性会加入结果。 |
numeric_prefix | 如果在基础数组中使用了数字下标同时给出了该参数, 此参数值将会作为基础数组中的数字下标元素的前缀。 这是为了让 PHP 或其它 CGI 程序在稍后对数据进行解码时获取合法的变量名。 |
arg_separator | 除非指定并使用了这个参数,否则会用 arg_separator.output 来分隔参数。 |
enc_type | 默认使用PHP_QUERY_RFC1738。如果enc_type是PHP_QUERY_RFC1738, 则编码将会以» RFC 1738标准和application/x-www-form-urlencoded媒体类型进行编码, 空格会被编码成加号(+)。如果enc_type是PHP_QUERY_RFC3986, 将根据» RFC 3986编码,空格会被百分号编码(%20)。 |
- 提示:
只有一维数组的键名才会添加前缀
parse_str
将URL 的查询字符串(query string)解析成多个变量,并设置到当前作用域
void parse_str(string $str [,array &$arr] )
- 参数说明:
参数 | 说明 |
---|---|
str | 输入的字符串 |
arr | 如果设置了第二个变量arr, 变量将会以数组元素的形式存入到这个数组,作为替代。 |
parse_url
解析 URL,返回其组成部分
mixed parse_url(string $url [,int $component= -1] )
本函数解析一个 URL 并返回一个关联数组,包含在 URL 中出现的各种组成部分。
本函数不是用来验证给定 URL 的合法性的,只是将其分解为下面列出的部分。
不完整的 URL 也被接受,parse_url()会尝试尽量正确地将其解析。
- 参数说明:
参数 | 说明 |
---|---|
url | 要解析的 URL。无效字符将使用_来替换。 |
component | 指定 PHP_URL_SCHEME PHP_URL_HOST PHP_URL_PORT PHP_URL_USER PHP_URL_PASS PHP_URL_PATH PHP_URL_QUERY PHP_URL_FRAGMENT 其中一个来获取 URL 中指定的部分的string 除了指定为PHP_URL_PORT后将返回一个integer的值外其余将返回string |
- 返回值说明:
*对严重不合格的 URL, parse_url() 可能会返回 FALSE
如果省略了component参数,将返回一个关联数组array
在目前至少会有一个元素在该数组中。数组中可能的键有以下几种: *
- scheme - 如 http
- host
- port
- user
- pass
- path
- query - 在问号 ? 之后
- fragment - 在散列符号 # 之后
如果指定了component参数, parse_url() 返回一个 string
或在指定为 PHP_URL_PORT 时返回一个 integer 而不是 array
如果 URL 中指定的组成部分不存在,将会返回 NULL。
- 提示:
5.4.7 修复了 host 在 协议 省略时的识别。
本函数不能用于相对 URL。
parse_url() 是专门用来解析 URL 而不是 URI 的。
不过为遵从 PHP 向后兼容的需要有个例外,
对 file:// 协议允许三个斜线(file:///...)。其它任何协议都不能这样。
示例代码
<?php
$a='xxx';
$arr=array(
'a'=>1,
'b'=>2,
'c'=>array('c1'=>array('c1k'=>'c1v'),'c2'),
'd'
);
$origin_str=http_build_query($arr,'_');
print_r($origin_str);
/*
a=1&b=2&c%5Bc1%5D%5Bc1k%5D=c1v&c%5B0%5D=c2&_0=d
*/
$str=urldecode($origin_str);
print_r($str);
/*
a=1&b=2&c[c1][c1k]=c1v&c[0]=c2&_0=d
*/
parse_str($str);
print_r($a);echo "\n";//覆盖掉顶部的$a的赋值
print_r($b);echo "\n";
print_r($c);
print_r($_0);
/*
1
2
Array
(
[c1] => Array
(
[c1k] => c1v
)
[0] => c2
)
d
*/
parse_str($str,$str_output);
print_r($str_output);
/*
Array
(
[a] => 1
[b] => 2
[c] => Array
(
[c1] => Array
(
[c1k] => c1v
)
[0] => c2
)
[_0] => d
)
*/
?>