(PHP 5, PECL pecl_http:0.1.0-0.9.0)
http_build_query — Generar una cadena de consulta codificada estilo URL
Genera una cadena de consulta codificada estilo URL a partir de la matriz asociativa (o indexada) dada.
Puede ser una matriz u objeto que contenga propiedades.
El formulario puede ser una estructura uni-dimensional sencilla, o una matriz de matrices (que a su vez puede contener otras matrices).
Si se usan índices numéricos en la matriz base y se provee este parámetro, éste será añadido al comienzo de los índices numéricos para aquellos elementos encontrados sólo en la matriz base.
Esto es para permitir que se opere con nombres de variables legales cuando los datos sean decodificados por PHP u otra aplicación CGI más adelante.
arg_separator.output es usado para separar argumentos, a menos que este parámetro sea especificado, en cuyo caso éste será usado.
Devuelve una cadena codificada en forma URL.
Versión | Descripción |
---|---|
5.1.2 | Se agregó el parámetro separador_arg . |
5.1.3 | Los corchetes cuadrados son escapados. |
Example#1 Uso simple de http_build_query()
<?php
$datos = array('foo'=>'bar',
'baz'=>'boom',
'vaca'=>'leche',
'php'=>'procesador de hipertexto');
echo http_build_query($datos); // foo=bar&baz=boom&vaca=leche&php=procesador+de+hipertexto
echo http_build_query($data, '', '&'); // foo=bar&baz=boom&vaca=leche\&php=procesador+de+hipertexto
?>
Example#2 http_build_query() con elementos indexados numéricamente.
<?php
$datos = array('foo', 'bar', 'baz', 'boom', 'vaca' => 'leche',
'php' => 'procesador de hipertexto');
echo http_build_query($datos) . "\n";
echo http_build_query($datos, 'mivar_');
?>
El resultado del ejemplo seria:
0=foo&1=bar&2=baz&3=boom&vaca=leche&php=procesador+de+hipertexto mivar_0=foo&mivar_1=bar&mivar_2=baz&mivar_3=boom&vaca=leche&php=procesador+de+hipertexto
Example#3 http_build_query() con matrices complejas
<?php
$datos = array('usuario'=>array('nombre'=>'Bob Smith',
'edad'=>47,
'sexo'=>'M',
'fdm'=>'5/12/1956'),
'pasatiempos'=>array('golf', 'opera', 'poker', 'rap'),
'hijos'=>array('bobby'=>array('edad'=>12,
'sexo'=>'M'),
'sally'=>array('edad'=>8,
'sexo'=>'F')),
'CEO');
echo http_build_query($datos, 'banderas_');
?>
esto generará la salida: (acotada por razones de legibilidad)
usuario%5Bnombre%5D=Bob+Smith&usuario%5Bedad%5D=47&usuario%5Bsexo%5D=M& usuario%5Bfdm%5D=5%2F12%2F1956&pasatiempos%5B0%5D=golf&pasatiempos%5B1%5D=opera& pasatiempos%5B2%5D=poker&pasatiempos%5B3%5D=rap&hijos%5Bbobby%5D%5Bedad%5D=12& hijos%5Bbobby%5D%5Bsexo%5D=M&hijos%5Bsally%5D%5Bedad%5D=8& hijos%5Bsally%5D%5Bsexo%5D=F&banderas_0=CEO
Note: Sólo el elemento "CEO" indexado numéricamente en la matriz base recibió un prefijo. Los otros índices numéricos, encontrados bajo los pasatiempos, no requieren un prefijo tipo cadena para ser nombres legales de variables.
Example#4 Uso de http_build_query() con un objeto
<?php
class miClase {
var $foo;
var $baz;
function miClase() {
$this->foo = 'bar';
$this->baz = 'boom';
}
}
$datos = new miClase();
echo http_build_query($datos); // foo=bar&baz=boom
?>