¿Alguien puede mostrarme cómo hacer un php curl con un HTTP POST?
Quiero enviar datos como este:
username=user1, password=passuser1, gender=1
A www.domain.com
Espero que el rizo devuelva una respuesta como result=OK
. ¿Hay algún ejemplo?
<?php
//
// A very simple PHP example that sends a HTTP POST to a remote site
//
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,"http://www.example.com/tester.phtml");
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS,
"postvar1=value1&postvar2=value2&postvar3=value3");
// In real life you should use something like:
// curl_setopt($ch, CURLOPT_POSTFIELDS,
// http_build_query(array('postvar1' => 'value1')));
// Receive server response ...
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$server_output = curl_exec($ch);
curl_close ($ch);
// Further processing ...
if ($server_output == "OK") { ... } else { ... }
?>
http_build_query()
para manejar parámetros; solo pasa la matriz aCURLOPT_POSTFIELDS
es suficiente.CURLOPT_POSTFIELDS
es una matriz, elContent-Type
encabezado se establecerá enmultipart/form-data
lugar deapplication/x-www-form-urlencoded
. php.net/manual/en/function.curl-setopt.phptrue
lugar de1
paraCURLOPT_POST
.Procesal
Orientado a objetos
Uso
Nota al margen aquí: sería mejor crear algún tipo de interfaz llamada,
AdapterInterface
por ejemplo, congetResponse()
método y dejar que la clase anterior lo implemente. Luego, siempre puede intercambiar esta implementación con otro adaptador de su gusto, sin efectos secundarios para su aplicación.Usando HTTPS / cifrando el tráfico
Por lo general, hay un problema con cURL en PHP bajo el sistema operativo Windows. Al intentar conectarse a un punto final protegido https, recibirá un error que le indicará eso
certificate verify failed
.Lo que la mayoría de la gente hace aquí es decirle a la biblioteca cURL que simplemente ignore los errores de certificado y continúe (
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
). Como esto hará que su código funcione, introduce un gran agujero de seguridad y permite que los usuarios malintencionados realicen varios ataques en su aplicación, como el ataque Man In The Middle o similar .Nunca, nunca hagas eso. En cambio, simplemente necesita modificar su
php.ini
y decirle a PHP dónde está suCA Certificate
archivo para que pueda verificar los certificados correctamente:Lo último
cacert.pem
se puede descargar de Internet o extraer de su navegador favorito . Al cambiar cualquierphp.ini
configuración relacionada, recuerde reiniciar su servidor web.fuente
Un ejemplo en vivo del uso de php curl_exec para hacer una publicación HTTP:
Pon esto en un archivo llamado foobar.php:
Luego ejecútelo con el comando
php foobar.php
, volcará este tipo de salida en la pantalla:Entonces hiciste una POST PHP a www.google.com y le enviaste algunos datos.
Si el servidor hubiera sido programado para leer las variables de publicación, podría decidir hacer algo diferente en función de eso.
fuente
$postvars .= $key . $value;
debería$postvars .= $key . $value ."&";
o no?$fields
matriz y generará una cadena de consulta.curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($fields));
http_build_query
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);
Se puede llegar fácilmente con:
fuente
Curl Post + Error Handling + Set Headers [gracias a @ mantas-d]:
fuente
fuente
curl_close
dentro de unfinally
bloque.Si el formulario usa redireccionamientos, autenticación, cookies, SSL (https) o cualquier otra cosa que no sea un script totalmente abierto que espera variables POST, comenzará a rechinar los dientes muy rápido. Eche un vistazo a Snoopy , que hace exactamente lo que tiene en mente al tiempo que elimina la necesidad de configurar gran parte de la sobrecarga.
fuente
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
Una respuesta más simple SI está pasando información a su propio sitio web es usar una variable SESSION. Comience la página php con:
Si en algún momento hay información que desea generar en PHP y pasar a la siguiente página de la sesión, en lugar de utilizar una variable POST, asígnela a una variable SESSION. Ejemplo:
Luego, en la página siguiente, simplemente haga referencia a esta variable SESIÓN. NOTA: después de usarlo, asegúrese de destruirlo para que no persista después de usarlo:
fuente
Aquí hay un código repetitivo para PHP + curl http://www.webbotsspidersscreenscrapers.com/DSP_download.php
incluir en estas bibliotecas simplificará el desarrollo
fuente
Si intenta iniciar sesión en el sitio con cookies.
Este código:
Es posible que no funcione si intenta iniciar sesión, porque muchos sitios devuelven el estado 200, pero la publicación no es exitosa.
Una manera fácil de verificar si la publicación de inicio de sesión es exitosa es verificar si configura las cookies nuevamente. Si en la salida tiene una cadena Set-Cookies, esto significa que las publicaciones no son exitosas y comienza una nueva sesión.
Además, la publicación puede ser exitosa, pero el estado se puede redirigir en lugar de 200.
Para estar seguro de que la publicación es exitosa, intente esto:
Siga la ubicación después de la publicación, por lo que irá a la página donde la publicación redirige a:
Y luego verifique si existen nuevas cookies en la solicitud:
fuente
Ejemplos de envío de formulario y datos sin procesar :
fuente