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$cadena_original='||'; //inicializamos en pipes doble la cadena original
if($eempres == "emisordif a la razon social")
{
$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]"); }
$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]", 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]",
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");
//-------
//-------CONSTRUIMOS UN XML CON LOS DATOS DEL ARRAY------
//-------
$nodo="";$esquemas=true; global $xml, $cadena_original, $conn; error_reporting(E_ALL);
$rsocialsinpuntos=str_replace(".","",$row1['RSocial']); $nufa = $arr['serie']." ".$arr['folio']." ".$rsocialsinpuntos;// Junta el numero de factura serie + folio
$xml = new DOMdocument("1.0","UTF-8"); //Datos generales del Comprobante
$root = $xml->createElement("Comprobante");
$root = $xml->appendChild($root);
if ($esquemas==true)
{
#7/Dic/2006 porque los necios de Levicom (para chedraui) no quieren estos elmentos, dicen que su validador lo agrega
cargaAtt
($root, array("xmlns"=>"http://www.sat.gob.mx/cfd/2", "xmlns:xsi"=>"http://www.w3.org/2001/XMLSchema-instance",
"xsi:schemaLocation"=>"http://www.sat.gob.mx/cfd/2 http://www.sat.gob.mx/sitio_internet/cfd/2/cfdv2.xsd"));
}
cargaAtt
($root, array("version"=>$arr['version'], "serie"=>$arr['serie'],
"folio"=>$arr['folio'],
"fecha"=>$arr['fecha'],
"sello"=>"@",
"noAprobacion"=>$arr['noAprobacion'],
"anoAprobacion"=>$arr['anoAprobacion'],"tipoDeComprobante"=>$arr['tipoDeComprobante'],
"formaDePago"=>$arr['formaDePago'],
"condicionesDePago"=>$arr['condicionesDePago'],
"noCertificado"=>$arr['noCertificado'],
"certificado"=>"@",
"subTotal"=>$arr['subTotal'],
"descuento"=>"0",
"total"=>$arr['total']
));
$emisor = $xml->createElement("Emisor"); //Datos del Emisor
$emisor = $root->appendChild($emisor);
cargaAtt
($emisor, array("rfc"=>$arr['rfcE'],"nombre"=>$arr['emisor']));
$domfis = $xml->createElement("DomicilioFiscal");
$domfis = $emisor->appendChild($domfis);
cargaAtt
($domfis, array("calle"=>$arr['calleE'], "noExterior"=>$arr['noExteriorE'],
"noInterior"=>$arr['noInteriorE'],
"colonia"=>$arr['coloniaE'],
"municipio"=>$arr['municipioE'],
"estado"=>$arr['estadoE'],
"pais"=>$arr['paisE'],
"codigoPostal"=>$arr['codigoPostalE']));
if($eempres == "emisordif a la razon social") //solo para el caso en que el domicilio de expedicion no se el mismo que la RS
{
$expedido = $xml->createElement("ExpedidoEn");
$expedido = $emisor->appendChild($expedido);
cargaAtt
($expedido, array("calle"=>$arre['calleEE'], "colonia"=>$arre['coloniaEE'],
"municipio"=>$arre['municipioEE'],
"estado"=>$arre['estadoEE'],
"pais"=>$arre['paisEE'],
"codigoPostal"=>$arre['codigoPostalEE']));
}
$receptor = $xml->createElement("Receptor"); //Datos del Receptor
$receptor = $root->appendChild($receptor);
cargaAtt
($receptor, array("rfc"=>$arr['rfcR'],"nombre"=>$arr['receptor']));
$domicilio = $xml->createElement("Domicilio");
$domicilio = $receptor->appendChild($domicilio);
cargaAtt
($domicilio, array("calle"=>$arr['calleR'], "colonia"=>$arr['coloniaR'],
"municipio"=>$arr['municipioR'],
"estado"=>$arr['estadoR'],
"pais"=>$arr['paisR'],
"codigoPostal"=>$arr['codigoPostalR']));
$conceptos = $xml->createElement("Conceptos"); //Detalle de los conceptos/produtos de la factura
$conceptos = $root->appendChild($conceptos);
$data = mysql_query("SELECT productos.*,facturasd.* FROM facturasd LEFT JOIN productos ON productos.IdProducto = facturasd.IdProducto
WHERE facturasd.IdEncabezado = '$Id' ORDER BY facturasd.Id DESC")or
die(mysql_error());
{
if($row2['idUmedida']=="Millar"){$cantidad=$row2['Cantpzas']/1000;}
if($row2['idUmedida']=="Piezas"){$cantidad=$row2['Cantpzas'];}
if($row2['idUmedida']=="Kilos"){$cantidad=$row2['Cantkgs'];}
if($row2['idUmedida']=="Libras"){$cantidad=$row2['CantEnLibras'];}
$concepto = $xml->createElement("Concepto");
$concepto = $conceptos->appendChild($concepto);
cargaAtt
($concepto, array("cantidad"=>$cantidad, "unidad"=>$row2['idUmedida'],
"noIdentificacion"=>$row2['IdProducto'],
"descripcion"=>$row2['Nombre'],
"valorUnitario"=>$row2['PrecioUni'],
"importe"=>$row2['PrecioTotal']));
}
$impuestos = $xml->createElement("Impuestos"); //Impuesto (IVA)
$impuestos = $root->appendChild($impuestos);
if($row1['ConceptoDocto']==2) //Retenciones
{
cargaAtt
($impuestos, array("totalImpuestosRetenidos"=>$arr['importe'])); if (isset($arr['importe'])) {
$retenciones = $xml->createElement("Retenciones");
$retenciones = $impuestos->appendChild($retenciones);
$retencion = $xml->createElement("Retencion");
$retencion = $retenciones->appendChild($retencion);
cargaAtt
($retencion, array("impuesto"=>$arr['impuestoiva'],"importe"=>$arr['importe'])); }
}
else //Traslados
{
cargaAtt
($impuestos, array("totalImpuestosTrasladados"=>$arr['importe'])); if (isset($arr['importe'])) {
$traslados = $xml->createElement("Traslados");
$traslados = $impuestos->appendChild($traslados);
$traslado = $xml->createElement("Traslado");
$traslado = $traslados->appendChild($traslado);
cargaAtt
($traslado, array("impuesto"=>$arr['impuestoiva'],"tasa"=>$arr['tasa'],"importe"=>$arr['importe'])); }
}
$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