1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?php /* 1.将数组内非空参数值的参数按照参数名从小到大排序(ASCII码字典序) * 2.然后使URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串 */ function ASCII($params = array()){ //ksort()对数组按照键名进行升序排序 ksort($params); $str = http_build_query($params, '', '&'); return $str; } //调用方式: $data=input('post.'); $stringTemp=$this->ASCII($data); ?> |
ksort() 函数:
1、定义:按照键名对关联数组进行升序排序
2、语法:
ksort(array,sortingtype);
参数:
参数 | 描述 |
---|---|
array | 必需。规定要进行排序的数组。 |
sortingtype |
可选。规定如何排列数组的元素/项目。可能的值:
|
说明:
ksort() 函数按照键名对数组排序,为数组值保留原来的键。
可选的第二个参数包含附加的排序标志。
若成功,则返回 TRUE,否则返回 FALSE。
其他:
返回值 | 如果成功则返回 TRUE,如果失败则返回 FALSE。 |
PHP 版本 | 4+ |
http_build_query ()函数:
定义:生成 URL-encode 之后的请求字符串,即使用给出的关联(或下标)数组生成一个经过 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:http_build_query生成的字符串中各参数之间的连接符号是由php.ini中的 arg_separator.output 来决定,默认的是&除非指定并使用了这个参数,否则会用 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)。
返回值:
返回一个 URL 编码后的字符串。
示例:
1 2 3 4 5 6 7 8 | $data = array('name'=>'xiao7', 'age'=>18, 'sex'=>'man', 'language'=>'php java'); echo http_build_query($data) . "<br>"; echo http_build_query($data, '', '&')."<br>"; echo http_build_query($data, '', ini_get('arg_separator.output'),PHP_QUERY_RFC3986); |
输出结果:
name=xiao7&age=18&sex=man&language=php+java
name=xiao7&age=18&sex=man&language=php+java
name=xiao7&age=18&sex=man&language=php%20java