Foros del Web » Programando para Internet » PHP »

Visualizar PDF usando ajax y php

Estas en el tema de Visualizar PDF usando ajax y php en el foro de PHP en Foros del Web. Buen día Amigos. Necesito visualizar un archivo pdf de la siguiente manera: Tengo un archivo index.html y dentro de el tengo una tabla con varias ...
  #1 (permalink)  
Antiguo 12/04/2017, 08:40
Avatar de laureano59  
Fecha de Ingreso: febrero-2005
Mensajes: 395
Antigüedad: 19 años, 2 meses
Puntos: 1
Visualizar PDF usando ajax y php

Buen día Amigos.

Necesito visualizar un archivo pdf de la siguiente manera:

Tengo un archivo index.html y dentro de el tengo una tabla con varias filas y una columna pdf.
necesito que al dar click en cualquiera de las filas de la columna pdf se visualice el documento pdf perteneciente a la fila.
esta es la fila que llama a una función onclick="VerPdf({$es.numero_esc},{$es.ano_esc});

Ahí no hay problema, llama a la función y pasa los parametros.

Código HTML:
<td style="text-align: center;"><a href="#" onclick="VerPdf({$es.numero_esc},{$es.ano_esc});"><img src="styles/image/iconos/ojo.png" width="32" height="32"></a></td> 

y esta es la funcion que contiene el AJAX el cual llama el php que debe cargar

java
__________________
http://www.weblaum.com
Laureano Melo Medina
:arriba:
  #2 (permalink)  
Antiguo 12/04/2017, 08:43
 
Fecha de Ingreso: septiembre-2012
Ubicación: Pontevedra
Mensajes: 48
Antigüedad: 11 años, 7 meses
Puntos: 2
Respuesta: Visualizar PDF usando ajax y php

que utilizas AngularJS?, por cierto no has puesto la función Javascript
  #3 (permalink)  
Antiguo 12/04/2017, 08:50
Avatar de laureano59  
Fecha de Ingreso: febrero-2005
Mensajes: 395
Antigüedad: 19 años, 2 meses
Puntos: 1
Respuesta: Visualizar PDF usando ajax y php

Que raro no dejó poner la función javascript ni el php:

aqui las dejo:

Código HTML:
<script>

function creaObjetoAjax () { //Mayoría de navegadores
  var obj;
  if (window.XMLHttpRequest) {
    obj=new XMLHttpRequest();
    }else { //para IE 5 y IE 6
      obj=new ActiveXObject(Microsoft.XMLHTTP);
      }
      return obj;
}

function VerPdf(numero_esc, ano_esc){
  
  var form;
  form = 'numero_esc=' + numero_esc + '&ano_esc=' + ano_esc;
  objetoAjax=creaObjetoAjax();
  objetoAjax.open('POST','?view=abrirpdf',true);
  objetoAjax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  objetoAjax.setRequestHeader("Content-length", form.length);
  objetoAjax.setRequestHeader("Connection", "close");
  objetoAjax.onreadystatechange = recogeDatos;
  objetoAjax.send(form);
}

function recogeDatos(){
  if (objetoAjax.readyState==4 && objetoAjax.status==200){
    miTexto=objetoAjax.responseText;
    //console.log(miTexto);
  }
}

</script> 
y este es el PHP:
Código PHP:
if(isset($_SESSION['id'],$_SESSION['usuario'],$_SESSION['email'])){
  if(isset(
$_POST['numero_esc']) and isset($_POST['ano_esc'])){

    
$ext 'pdf';
    
$pdf $_POST['numero_esc'] . $_POST['ano_esc'];
    
$ruta 'uploads/escrituras/'.$pdf '.' $ext;
    
//header('Content-type: application/pdf');
    //header('Content-Disposition: attachment; filename="'.$ruta.'"');
    //readfile($ruta);

    
echo $ruta;
  }else{
    echo 
2;
  }

}else{
    
header('location: ?view=index');


La cuestión es la siguiente: el php recibe sin problema lo que manda el AJAX pero en el momento de abrir el PDF se queda pensando y en el ajax si muestro por consola lo que retorna el php es un codigo con un monton de signos y bloquea el navegador.

No se si me estoy complicando pero necesito abrir el pdf . Trabajo con MVC.

Gracias
__________________
http://www.weblaum.com
Laureano Melo Medina
:arriba:
  #4 (permalink)  
Antiguo 12/04/2017, 14:33
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Visualizar PDF usando ajax y php

Todos esos símbolos son el contenido del PDF.

Ahora, en HTML no puedes mostrar directamente documentos y solo algunos navegadores incorporan visor de PDF, pero se tienen que abrir en otra ventana o pestaña.
__________________
- León, Guanajuato
- GV-Foto
  #5 (permalink)  
Antiguo 13/04/2017, 10:54
 
Fecha de Ingreso: octubre-2007
Mensajes: 273
Antigüedad: 16 años, 6 meses
Puntos: 5
Respuesta: Visualizar PDF usando ajax y php

Y por qué vía AJAX ?? devolver una respuesta con los headers adecuados ('Content-type: application/pdf') no hace que recargue tu página.
  #6 (permalink)  
Antiguo 13/04/2017, 11:40
Avatar de laureano59  
Fecha de Ingreso: febrero-2005
Mensajes: 395
Antigüedad: 19 años, 2 meses
Puntos: 1
Respuesta: Visualizar PDF usando ajax y php

Lo que pasa es que debo mandar unas variables a php que sería el nombre del archivo pdf, y no se de que otra manera hacerlo, de modo que pueda desde php abrir en una nueva pestaña el archivo PDF, recuerde que la pagina de donde mando las variables es html.

Aclaro algo del PHP : lo que está en comentarios no son comentarios lo que pasa es que sin querer lo pegue así.
__________________
http://www.weblaum.com
Laureano Melo Medina
:arriba:
  #7 (permalink)  
Antiguo 13/04/2017, 11:46
 
Fecha de Ingreso: octubre-2007
Mensajes: 273
Antigüedad: 16 años, 6 meses
Puntos: 5
Respuesta: Visualizar PDF usando ajax y php

Pues entonces en el href del vínculo pasa la url de donde proviene el PDF junto con las varibles que necesites del lado del servidor y obtenlas vía GET.
  #8 (permalink)  
Antiguo 13/04/2017, 12:23
alvaro_trewhela
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Visualizar PDF usando ajax y php

Por parte del servidor obtener la ruta del archivo y muestras..

Código HTML:
Ver original
  1.     <head>
  2.         <script type="text/javascript">
  3.         function seePdf(){
  4.         //todo tu ajax aca...
  5.         document.getElementById("pdf").setAttribute("src", respuestaAjax);
  6.         }
  7.         </script>
  8.     </head>
  9.     <body>
  10.         <embed src="RESPUESTA RUTA ACA" id="pdf" width="ancho" height="alto" />
  11.     </body>
  12. </html>

Por php:

Código PHP:
Ver original
  1. <?php
  2.  
  3. $ruta = "tu/ruta"; // ruta completa sin / final
  4.  
  5. $pdf = $_POST["recurso"];
  6. //o get no se cual usas...
  7. $pdf = $_GET["recurso"];
  8.  
  9. /*
  10.  
  11. aca toda progra...
  12.  
  13. */
  14.  
  15. echo "$ruta/$retornoDeTuProgra";
  16.  
  17. ?>

Yo probé esto:

Código HTML:
Ver original
  1.     <head>
  2.         <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  3.         <title>AJAX</title>
  4.        
  5.         <script type="text/javascript">
  6.        
  7.        
  8.         function createREQ() {
  9.                 try {
  10.                 req = new XMLHttpRequest(); /* p.e. Firefox */
  11.                 }
  12.                 catch(err1){
  13.                     try {
  14.                     req = new ActiveXObject('Msxml2.XMLHTTP'); /* algunas versiones IE */
  15.                     }
  16.                     catch (err2) {
  17.                         try {
  18.                         req = new ActiveXObject("Microsoft.XMLHTTP"); /* algunas versiones IE */
  19.                         }
  20.                         catch (err3) {
  21.                         req = false;
  22.                         }
  23.                     }
  24.                 }
  25.         return req;
  26.         }
  27.        
  28.        
  29.         function mostrarpdf(){
  30.         var pdf = document.getElementById("pdf");
  31.             if(pdf.value == "0"){ alert("elija!!"); return false; }
  32.         var http = new createREQ();
  33.         http.open("POST", "seePdf.php", true);
  34.         http.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  35.         var archivo = document.getElementById("pdf").value;
  36.         http.send("archivo="+archivo); 
  37.        
  38.         http.onreadystatechange = function(){
  39.                 if(http.readyState == 4 && http.status == 200){
  40.                 var response = http.responseText;
  41.                 document.getElementById("emb").setAttribute("src", response);
  42.                 }
  43.             };
  44.         }
  45.         </script>
  46.    
  47.     </head>
  48.     <body>
  49.         <select id="pdf" onchange="mostrarpdf();">
  50.             <option value="0">Elejir</option>
  51.             <option value="cotizacion.pdf">Pdf cotizacion</option>
  52.             <option value="tarea.pdf">Pdf tarea</option>
  53.             <option value="certificado.pdf">Pdf certificado</option>
  54.         </select>
  55.         <br/><br/><br/>
  56.         <embed src="" width="500" height="500" id="emb"/>
  57.     </body>
  58. </html>

PHP:

Código PHP:
Ver original
  1. <?php
  2.  
  3. $ruta = "archivos/pdf"; //ruta sin / final
  4.  
  5. $archivo = $_POST["archivo"];
  6.  
  7. echo "$ruta/$archivo";
  8.  
  9. ?>

y tengo un escritorio con los pdf...

usa eso como ejemplo, no se si es lo mejor, este es mi template de ajax

Última edición por alvaro_trewhela; 13/04/2017 a las 13:10

Etiquetas: ajax, html, pdf, usando
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 21:23.