http_build_query
(PHP 5, PECL pecl_http:0.1.0-0.9.0)
http_build_query — Generar una cadena de consulta codificada estilo URL
Descripción
Genera una cadena de consulta codificada estilo URL a partir de la matriz asociativa (o indexada) dada.
Lista de parámetros
- datos_formulario
-
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).
- prefijo_numerico
-
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.
- separador_arg
-
arg_separator.output es usado para separar argumentos, a menos que este parámetro sea especificado, en cuyo caso éste será usado.
Valores retornados
Devuelve una cadena codificada en forma URL.
Registro de cambios
Versión | Descripción |
---|---|
5.1.2 | Se agregó el parámetro separador_arg . |
5.1.3 | Los corchetes cuadrados son escapados. |
Ejemplos
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
?>