Ver Mensaje Individual
  #250 (permalink)  
Antiguo 22/10/2010, 13:43
Avatar de Nanox
Nanox
 
Fecha de Ingreso: octubre-2008
Ubicación: Apizaco/Tlaxcala/Mexico
Mensajes: 20
Antigüedad: 16 años
Puntos: 0
Respuesta: Factura electroncia sat mexico

Compañebrios ya tengo el problema solucionado en PHP.... a todos gracias por sus aportes. yo inicie esto hace 1 año, fui de los primeros posteadores en otro hilo, pero lo deje por otras cosillas, regrese esta semana porque me mandaron mis certificados y folios, y ps hora si iba en serio jjjj. tons me chute otravez el codigo del lacorona.com.mx/fortiz, gracias a este cuate que ni conozco pero ps puso sus maravillas en la red, la mayoria de su codigo me funciono y ya quedo.
Mi hibrido aun no lleva addendas solo agreguenlas, y unas que otras cossas como la version 2 del xlst que da el sat. igual y falta algo pero si ustedes como yo, no abandonamos estos hilos, sabremos que sigue.... amenos eso espero--> que no se den su pakete y decidan no postear por pensar que otro se puede hacer rico con su codigo,jaja, sino de una vez lleguenle... hay les va la primer entrega.....esta todo cochinote, pero hay les va un cachote que crea el xml sin certificado ni sello..

//-----

Código PHP:
Ver original
  1. $cadena_original='||';                                     //inicializamos en pipes doble la cadena original
  2.        
  3.    
  4.    
  5.     if($eempres == "emisordif a la razon social")
  6.     {
  7.    
  8.     $arre=array(calleEE=>"$factelectro_emisor[Calle]",coloniaEE=>"$factelectro_emisor[Colonia]",municipioEE=>"$factelectro_emisor[Municipio]",estadoEE=>"$factelectro_emisor[Estado]",paisEE=>"$factelectro_emisor[Pais]",codigoPostalEE=>"$factelectro_emisor[CP]");
  9.     }
  10.         $arr=array(version=>"2.0",serie=>"$factelectro[Serie]",folio=>"$row1[IdDocumento]",fecha=>"$fecha",sello=>"",noAprobacion=>"$naproba",anoAprobacion=>"$anoAprobacion",tipoDeComprobante=>"$row1[TipoCFD]",formaDePago=>"$infoformdpago",condicionesDePago=>"$infocondpago",noCertificado=>"$numeroCer",certificado=>"",subTotal=>"$row1[SubTotal]",total=>"$row1[TotalDocto]",
  11.     rfcE=>"$factelectro[RFC]",emisor=>"$factelectro[RSocial]",calleE=>"$factelectro[Calle]",noExteriorE=>"$factelectro[NumeroE]",noInteriorE=>"$factelectro[NumeroI]",coloniaE=>"$factelectro[Colonia]",municipioE=>"$factelectro[Municipio]",estadoE=>"$factelectro[Estado]",paisE=>"$factelectro[Pais]",codigoPostalE=>"$factelectro[CP]",
  12.     rfcR=>"$row1[rfcc]",receptor=>"$row1[RSocial]",calleR=>"$row1[Direccion]",coloniaR=>"$row1[Colonia]",municipioR=>"$row1[Ciudad]",estadoR=>"$row1[Estado]",paisR=>"MEXICO",codigoPostalR=>"$row1[CP]",Conceptos=>$totalp,impuestoiva=>"IVA",tasa=>"$row1[IVA]",importe=>"$row1[TotalIVA]",fechaEmbarque=>"$fecha",fechaVence=>"$fecha");
  13.    
  14.     //-------
  15.     //-------CONSTRUIMOS UN XML CON LOS DATOS DEL ARRAY------
  16.     //-------
  17.    
  18.     $nodo="";$esquemas=true; global $xml, $cadena_original, $conn; error_reporting(E_ALL); 
  19.    
  20.     $rsocialsinpuntos=str_replace(".","",$row1['RSocial']);        
  21.     $nufa = $arr['serie']." ".$arr['folio']." ".$rsocialsinpuntos;// Junta el numero de factura   serie + folio  
  22.     $xml = new DOMdocument("1.0","UTF-8");                        //Datos generales del Comprobante
  23.     $root = $xml->createElement("Comprobante");
  24.     $root = $xml->appendChild($root);
  25.     if ($esquemas==true)
  26.     {
  27.         #7/Dic/2006  porque los necios de Levicom (para chedraui) no quieren estos elmentos, dicen que su validador lo agrega
  28.        cargaAtt($root, array("xmlns"=>"http://www.sat.gob.mx/cfd/2",
  29.                           "xmlns:xsi"=>"http://www.w3.org/2001/XMLSchema-instance",
  30.                           "xsi:schemaLocation"=>"http://www.sat.gob.mx/cfd/2 http://www.sat.gob.mx/sitio_internet/cfd/2/cfdv2.xsd"));
  31.     }
  32.     cargaAtt($root, array("version"=>$arr['version'],
  33.                           "serie"=>$arr['serie'],
  34.                           "folio"=>$arr['folio'],
  35.                           "fecha"=>$arr['fecha'],
  36.                           "sello"=>"@",
  37.                           "noAprobacion"=>$arr['noAprobacion'],
  38.                           "anoAprobacion"=>$arr['anoAprobacion'],"tipoDeComprobante"=>$arr['tipoDeComprobante'],
  39.                           "formaDePago"=>$arr['formaDePago'],
  40.                           "condicionesDePago"=>$arr['condicionesDePago'],
  41.                           "noCertificado"=>$arr['noCertificado'],
  42.                           "certificado"=>"@",
  43.                           "subTotal"=>$arr['subTotal'],
  44.                           "descuento"=>"0",
  45.                           "total"=>$arr['total']
  46.                           ));
  47.    
  48.     $emisor = $xml->createElement("Emisor");                //Datos del Emisor
  49.     $emisor = $root->appendChild($emisor);
  50.     cargaAtt($emisor, array("rfc"=>$arr['rfcE'],"nombre"=>$arr['emisor']));
  51.    
  52.     $domfis = $xml->createElement("DomicilioFiscal");
  53.     $domfis = $emisor->appendChild($domfis);
  54.     cargaAtt($domfis, array("calle"=>$arr['calleE'],
  55.                             "noExterior"=>$arr['noExteriorE'],
  56.                             "noInterior"=>$arr['noInteriorE'],
  57.                             "colonia"=>$arr['coloniaE'],
  58.                             "municipio"=>$arr['municipioE'],
  59.                             "estado"=>$arr['estadoE'],
  60.                             "pais"=>$arr['paisE'],
  61.                             "codigoPostal"=>$arr['codigoPostalE']));
  62.    
  63.     if($eempres == "emisordif a la razon social")                                 //solo para el caso en que el domicilio de expedicion no se el mismo que la RS
  64.     {
  65.     $expedido = $xml->createElement("ExpedidoEn");
  66.     $expedido = $emisor->appendChild($expedido);
  67.     cargaAtt($expedido, array("calle"=>$arre['calleEE'],
  68.                             "colonia"=>$arre['coloniaEE'],
  69.                             "municipio"=>$arre['municipioEE'],
  70.                             "estado"=>$arre['estadoEE'],
  71.                             "pais"=>$arre['paisEE'],
  72.                             "codigoPostal"=>$arre['codigoPostalEE']));
  73.     }                                                
  74.    
  75.    
  76.     $receptor = $xml->createElement("Receptor");            //Datos del Receptor
  77.     $receptor = $root->appendChild($receptor);
  78.     cargaAtt($receptor, array("rfc"=>$arr['rfcR'],"nombre"=>$arr['receptor']));
  79.    
  80.     $domicilio = $xml->createElement("Domicilio");
  81.     $domicilio = $receptor->appendChild($domicilio);
  82.     cargaAtt($domicilio, array("calle"=>$arr['calleR'],
  83.                            "colonia"=>$arr['coloniaR'],
  84.                            "municipio"=>$arr['municipioR'],
  85.                            "estado"=>$arr['estadoR'],
  86.                            "pais"=>$arr['paisR'],
  87.                            "codigoPostal"=>$arr['codigoPostalR']));
  88.    
  89.    
  90.     $conceptos = $xml->createElement("Conceptos");              //Detalle de los conceptos/produtos de la factura
  91.     $conceptos = $root->appendChild($conceptos);
  92.    
  93.     $data = mysql_query("SELECT productos.*,facturasd.* FROM facturasd
  94.    LEFT JOIN productos ON productos.IdProducto = facturasd.IdProducto
  95.    WHERE facturasd.IdEncabezado = '$Id' ORDER BY facturasd.Id DESC")or die(mysql_error());
  96.    
  97.     while ($row2 = mysql_fetch_array($data))                    //numero de partidas de la factura
  98.     {
  99.         if($row2['idUmedida']=="Millar"){$cantidad=$row2['Cantpzas']/1000;}
  100.         if($row2['idUmedida']=="Piezas"){$cantidad=$row2['Cantpzas'];}
  101.         if($row2['idUmedida']=="Kilos"){$cantidad=$row2['Cantkgs'];}
  102.         if($row2['idUmedida']=="Libras"){$cantidad=$row2['CantEnLibras'];}
  103.    
  104.         $concepto = $xml->createElement("Concepto");
  105.         $concepto = $conceptos->appendChild($concepto);
  106.         cargaAtt($concepto, array("cantidad"=>$cantidad,
  107.                                   "unidad"=>$row2['idUmedida'],
  108.                                   "noIdentificacion"=>$row2['IdProducto'],
  109.                                   "descripcion"=>$row2['Nombre'],
  110.                                   "valorUnitario"=>$row2['PrecioUni'],
  111.                                   "importe"=>$row2['PrecioTotal']));
  112.     }
  113.    
  114.     $impuestos = $xml->createElement("Impuestos");              //Impuesto (IVA)
  115.     $impuestos = $root->appendChild($impuestos);
  116.    
  117.     if($row1['ConceptoDocto']==2)                               //Retenciones
  118.     {
  119.         cargaAtt($impuestos, array("totalImpuestosRetenidos"=>$arr['importe']));
  120.         if (isset($arr['importe']))
  121.         {
  122.             $retenciones = $xml->createElement("Retenciones");         
  123.             $retenciones = $impuestos->appendChild($retenciones);
  124.             $retencion = $xml->createElement("Retencion");
  125.             $retencion = $retenciones->appendChild($retencion);
  126.             cargaAtt($retencion, array("impuesto"=>$arr['impuestoiva'],"importe"=>$arr['importe']));
  127.         }
  128.     }
  129.     else                                                        //Traslados                                            
  130.     {
  131.         cargaAtt($impuestos, array("totalImpuestosTrasladados"=>$arr['importe']));
  132.         if (isset($arr['importe']))
  133.         {
  134.             $traslados = $xml->createElement("Traslados");         
  135.             $traslados = $impuestos->appendChild($traslados);
  136.             $traslado = $xml->createElement("Traslado");
  137.             $traslado = $traslados->appendChild($traslado);
  138.             cargaAtt($traslado, array("impuesto"=>$arr['impuestoiva'],"tasa"=>$arr['tasa'],"importe"=>$arr['importe']));
  139.         }
  140.     }
  141.  
  142.     $cadena_original.= "|";                         // termina la cadena original con el doble ||

//---


LA SEGUNDA ENTREGA EMPALMA EL XLST Y EL XML INCOMPLETO PARA OBTENER UNA CADENA ORIGINAL .. HACE EL SELLO Y LO AGREGA...

Saludos