Hola amigos del foro estoy desesperado he buscado pro arriba por abajo .. y no logro resolver mi problema...
bueno lo que intento es leer la CURP del código fuente de la siguiente pagina: http://consultas.curp.gob.mx/ para luego guardarla en una variable y ya después insertarla a mi Base de Datos.
Buscando y buscando aquí mismo en foros del web encontré un código de
http://www.forosdelweb.com/f18/problemas-con-cargar-pagina-con-curl-1103757/#post4622791
adaptándolo me quedo así:
Proceso.php
Código PHP:
///Aquí recibo los datos de un formulario ////
$nombre = urlencode ($al_nombres);
$primerApellido = urlencode ($al_paterno);
$segundoApellido = urlencode($al_materno);
$dia = urlencode($dia);
$mes = urlencode($mes);
$anio = urlencode($anio);
$sexo = urlencode($sexo);
$entidad = urlencode($entidad);
$codigo = urlencode($codigo);
$url ='http://consultas.curp.gob.mx/CurpSP/curp11.do?strPrimerApellido='.$primerApellido.'&strSegundoAplido='.$segundoApellido.'&strNombre='.$nombre.'&strdia='.$dia.'&strmes='.$mes.'&stranio='.$anio.'&sSexoA='.$sexo.'&sEntidadA='.$entidad.'&rdbBD=myoracle&strTipo=A&codigo='.$codigo;
include 'clase.php';
$http = new HttpConnection();
$http->setCookiePath("/my_cookie_path/");
$http->init();
$html = $http->get($url);
$http->close();
echo $html;
$body = ob_get_contents();
ob_end_clean();
$document = new DOMDocument();
$document->loadHTML($body);
$inputs = $document->getElementsByTagName("input");
foreach ($inputs as $input) {
if ($input->getAttribute("name") == "strCurp") {
$curp = $input->getAttribute("value");
echo $curp;
}
}
clase.php
Código PHP:
<?php
class HttpConnection {
private $curl;
private $cookie;
private $cookie_path="/cookies";
private $id;
public function __construct() {
$this->id = time();
}
/**
* Inicializa el objeto curl con las opciones por defecto.
* Si es null se crea
* @param string $cookie a usar para la conexion
*/
public function init($cookie=null) {
if($cookie)
$this->cookie = $cookie;
else
$this->cookie = $this->cookie_path . $this->id;
$this->curl=curl_init();
curl_setopt($this->curl, CURLOPT_USERAGENT,"Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1");
curl_setopt($this->curl, CURLOPT_HEADER, false);
curl_setopt($this->curl, CURLOPT_COOKIEFILE,$this->cookie);
curl_setopt($this->curl, CURLOPT_HTTPHEADER, array("Accept-Language: es-es,en"));
curl_setopt($this->curl, CURLOPT_COOKIEJAR, $this->cookie);
curl_setopt($this->curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($this->curl, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($this->curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);
curl_setopt($this->curl, CURLOPT_RETURNTRANSFER,true);
curl_setopt($this->curl, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($this->curl, CURLOPT_TIMEOUT, 60);
curl_setopt($this->curl, CURLOPT_AUTOREFERER, TRUE);
}
/**
* Establece en que ruta se guardan las cookies.
* Importante: El usuario de apache debe tener acceso de lectura y escritura
* @param string $path
*/
public function setCookiePath($path){
$this->cookie_path = $path;
}
/**
* Envía una peticion GET a la URL especificada
* @param string $url
* @param bool $follow
* @return string Respuesta generada por el servidor
*/
public function get($url,$follow=false) {
$this->init();
curl_setopt($this->curl, CURLOPT_URL, $url);
curl_setopt($this->curl, CURLOPT_POST,false);
curl_setopt($this->curl, CURLOPT_HEADER, $follow);
curl_setopt($this->curl, CURLOPT_REFERER, '');
curl_setopt($this->curl, CURLOPT_FOLLOWLOCATION, $follow);
$result=curl_exec ($this->curl);
if($result === false){
echo curl_error($this->curl);
}
$this->_close();
return $result;
}
/**
* Envía una petición POST a la URL especificada
* @param string $url
* @param array $post_elements
* @param bool $follow
* @param bool $header
* @return string Respuesta generada por el servidor
*/
public function post($url,$post_elements,$follow=false,$header=false) {
$this->init();
$elements=array();
foreach ($post_elements as $name=>$value) {
$elements[] = "{$name}=".urlencode($value);
}
$elements = join("&",$elements);
curl_setopt($this->curl, CURLOPT_URL, $url);
curl_setopt($this->curl, CURLOPT_POST,true);
curl_setopt($this->curl, CURLOPT_REFERER, '');
curl_setopt($this->curl, CURLOPT_HEADER, $header OR $follow);
curl_setopt($this->curl, CURLOPT_POSTFIELDS, $elements);
curl_setopt($this->curl, CURLOPT_FOLLOWLOCATION, $follow);
$result=curl_exec ($this->curl);
$this->_close();
return $result;
}
/**
* Descarga un fichero binario en el buffer
* @param string $url
* @return string
*/
public function getBinary($url){
$this->init();
curl_setopt($this->curl, CURLOPT_URL, $url);
curl_setopt($this->curl, CURLOPT_BINARYTRANSFER,1);
$result = curl_exec ($this->curl);
$this->_close();
return $result;
}
/**
* Cierra la conexión
*/
private function _close() {
curl_close($this->curl);
}
public function close(){
if(file_exists($this->cookie))
unlink($this->cookie);
}
}
?>
Si ejecuto solamente hasta antes del $body = ob_get_contents();...
me muestra la pagina
Sesi�n expirada, cierre �sta ventana y presione F5 para realizar otra consulta
y si ejecuto todo.. me me lanza los siguientes errores:
Warning: DOMDocument::loadHTML(): htmlParseStartTag: misplaced <html> tag in Entity, line: 14 in
Warning: DOMDocument::loadHTML(): htmlParseStartTag: misplaced <head> tag in Entity, line: 15 in
Warning: DOMDocument::loadHTML(): Input is not proper UTF-8, indicate encoding ! in Entity, line: 29 in
Warning: DOMDocument::loadHTML(): htmlParseStartTag: misplaced <body> tag in Entity, line: 42 in
Estoy desesperado cualquier ayuda, sugerencia ... se los agradeceré mucho