Foros del Web » Programando para Internet » PHP »

Problema al abrir un archivo XML

Estas en el tema de Problema al abrir un archivo XML en el foro de PHP en Foros del Web. Buenos dias, tengo rato intentando abrir archivos XML con PHP, los archivos estan en mi BD en un campo de tipo "longblob", que me recomiendan ...
  #1 (permalink)  
Antiguo 01/09/2014, 11:32
 
Fecha de Ingreso: noviembre-2011
Ubicación: Paris
Mensajes: 450
Antigüedad: 12 años, 5 meses
Puntos: 7
Problema al abrir un archivo XML

Buenos dias, tengo rato intentando abrir archivos XML con PHP, los archivos estan en mi BD en un campo de tipo "longblob", que me recomiendan hacer, de verdad se los agradezco. Estoy intentando con simplexml_load_file() pero se que esto no me ayudara del todo.
Saludos!
  #2 (permalink)  
Antiguo 01/09/2014, 12:38
Avatar de juan_14nob  
Fecha de Ingreso: abril-2010
Mensajes: 552
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema al abrir un archivo XML

¿Guardaste una estructura XML dentro de un campo de tu base de datos? Es lo mas desagradable que he visto en los años que llevo programando. De todos modos, no necesitas "abrir un archivo"

Lo que deberías hacer, es:
1- Haces un SELECT a la tabla de tu BD y guardas el XML en una variable algo asi:
Código PHP:
Ver original
  1. $xml = $consulta["campo_con_xml"];
2- Trabajas parseando $xml (como si fuera el archivo .xml)


Saludos
  #3 (permalink)  
Antiguo 01/09/2014, 12:50
 
Fecha de Ingreso: noviembre-2011
Ubicación: Paris
Mensajes: 450
Antigüedad: 12 años, 5 meses
Puntos: 7
Respuesta: Problema al abrir un archivo XML

Hola Juan, gracias por tu pronta respuesta. solo aclaro que yo no guarde el xml de esa manera, si no una empresa externa que realizo la aplicacion, intento lo siguiente pero no funca..

Código PHP:
                $data $this -> conect -> conexion();             
               
$dbquery $data -> prepare("SELECT * 
                                               FROM FILE 
                                               ORDER BY ID
                                               LIMIT 1
                                             "
);
               
$dbquery -> execute();     
               
$rows $dbquery->fetch(PDO::FETCH_ASSOC);
          



                    
$string $rows['BYTES'];

                 
var_dump(simplexml_load_file($string)); 
  #4 (permalink)  
Antiguo 01/09/2014, 13:00
Avatar de juan_14nob  
Fecha de Ingreso: abril-2010
Mensajes: 552
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema al abrir un archivo XML

Hiciste un
Código PHP:
Ver original
  1. var_dump($string);
para ver lo que te devuelve?
  #5 (permalink)  
Antiguo 01/09/2014, 13:05
 
Fecha de Ingreso: noviembre-2011
Ubicación: Paris
Mensajes: 450
Antigüedad: 12 años, 5 meses
Puntos: 7
Respuesta: Problema al abrir un archivo XML

Me regresa: string(4236) "", y con el simplexml_load_file(); me regresa
Código:
Warning: simplexml_load_file(): I/O warning : failed to load external entity "<?xml version="1.0" encoding="utf-8"?><cfdi:Comprobante xmlns:cfdi="http://www.sat.gob.mx/cfd/3" noCertificado="00001000000201575241" sello="WxENyY/Q81WKBUOIN6w8stx+E+jsjIWJQDFCOej2vjwV6oLvMVEXIGaPWMjGtIUTcNZ8PGZkvVDBmUaLoIsoSXVF6Hyz1flqJNh2MtyoFbyNcy50HoGObeP3YlvMdySQi8MRnsiGEMpdcaBj6LiVYlapFoCEA8gAU/H2nn5qm/c=" certificado="MIIEkzCCA3ugAwIBAgIUMDAwMDEwMDAwMDAyMDE1NzUyNDEwDQYJKoZIhvcNAQEFBQAwggGVMTgwNgYDVQQDDC9BLkMuIGRlbCBTZXJ2aWNpbyBkZSBBZG1pbmlzdHJhY2nDs24gVHJpYnV0YXJpYTEvMC0GA1UECgwmU2VydmljaW8gZGUgQWRtaW5pc3RyYWNpw7NuIFRyaWJ1dGFyaWExODA2BgNVBAsML0FkbWluaXN0cmFjacOzbiBkZSBTZWd1cmlkYWQgZGUgbGEgSW5mb3JtYWNpw7NuMSEwHwYJKoZIhvcNAQkBFhJhc2lzbmV0QHNhdC5nb2IubXgxJjAkBgNVBAkMHUF2LiBIaWRhbGdvIDc3LCBDb2wuIEd1ZXJyZXJvMQ4wDAYDVQQRDAUwNjMwMDELMAkGA1UEBhMCTVgxGTAXBgNVBAgMEERpc3RyaXRvIEZlZGVyYWwxFDASBgNVBAcMC0N1YXVodMOpbW9jMRUwEwYDVQQtEwxTQVQ5NzA3MDFOTjMxPjA8BgkqhkiG9w0BCQIML1Jlc3Bvbn in /var/www/client/lib/class/index.php on line 36
  #6 (permalink)  
Antiguo 01/09/2014, 13:11
Avatar de juan_14nob  
Fecha de Ingreso: abril-2010
Mensajes: 552
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema al abrir un archivo XML

1- descarta la opción de usar la función simplexml_load_file(); No te va a funcionar con lo que quieres hacer.

2- $tuxml = new SimpleXMLElement($string);

Fijate que te devuelve haciendo un print_r() o var_dump()
  #7 (permalink)  
Antiguo 01/09/2014, 13:23
 
Fecha de Ingreso: noviembre-2011
Ubicación: Paris
Mensajes: 450
Antigüedad: 12 años, 5 meses
Puntos: 7
Respuesta: Problema al abrir un archivo XML

Me imprime:
Código PHP:
SimpleXMLElement Object ( [@attributes] => Array ( [noCertificado] => 000345435354575241 [sello] => WxENyY/Q81WKBUOINdhgdgfhdhddfgcnvjwV6oLvMVEXIGaPWMjGtIUT 
Como imprimo cada arreglo?
  #8 (permalink)  
Antiguo 01/09/2014, 15:56
Avatar de juan_14nob  
Fecha de Ingreso: abril-2010
Mensajes: 552
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema al abrir un archivo XML

Supongo como si fuera un Array

Aca te dejo info para que practiques

https://php.net//manual/es/simplexml.examples-basic.php
  #9 (permalink)  
Antiguo 01/09/2014, 16:58
 
Fecha de Ingreso: noviembre-2011
Ubicación: Paris
Mensajes: 450
Antigüedad: 12 años, 5 meses
Puntos: 7
Respuesta: Problema al abrir un archivo XML

Gracias, ahora trato de imprimir todos los registros pero me tira este error:
Código PHP:
                     $dbquery->execute();
           while(
$rows $dbquery->fetch(PDO::FETCH_ASSOC)){
                  
$string $rows['BYTES'];
                    
$tuxml = new SimpleXMLElement(htmlspecialchars($string));
             echo 
$tuxml->attributes()->Moneda;
                 
           
                                 

           } 

Error:
Código:
Warning: SimpleXMLElement::__construct(): Entity: line 1: parser error : Start tag expected, '<' not found in /var/www/client/lib/class/index.php on line 34

Warning: SimpleXMLElement::__construct(): &lt;?xml version=&quot;1.0&quot; encoding=&quot;utf-8&quot;?&gt;&lt;cfdi:Comprob in /var/www/client/lib/class/index.php on line 34

Warning: SimpleXMLElement::__construct(): ^ in /var/www/client/lib/class/index.php on line 34

Fatal error: Uncaught exception 'Exception' with message 'String could not be parsed as XML' in /var/www/client/lib/class/index.php:34 Stack trace: #0 /var/www/client/lib/class/index.php(34): SimpleXMLElement->__construct('&lt;?xml versio...') #1 /var/www/client/lib/class/index.php(47): uuid->select() #2 {main} thrown in /var/www/client/lib/class/index.php on line 34
  #10 (permalink)  
Antiguo 01/09/2014, 18:37
Avatar de juan_14nob  
Fecha de Ingreso: abril-2010
Mensajes: 552
Antigüedad: 14 años
Puntos: 6
Respuesta: Problema al abrir un archivo XML

El error aparentemente esta porque cuando se guarda en la base de datos, no debe estar en formato UTF8 por lo tanto algunos caracteres cambian. y cuando vos los lees con el PHP y retornas el valor no esta esparando los valores correctos para poder parsear.

Por lo tanto a vos te esta tirando el error porque en la primer linea

Código XML:
Ver original
  1. &lt;?xml version=

En realidad esta esperando

Código XML:
Ver original
  1. <?xml version= ....

Etiquetas: xml
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 20:53.