![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Create SOAP with one VeriFactu Digitally Signed Registration RecordSee more Verifactu ExamplesCreates a SOAP message containing a single digitally signed invoice registration record, formatted according to the specifications for Spain's Veri*Factu system.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) DECLARE @success int SELECT @success = 0 SELECT @success = 1 -- Create the following SOAP XML containing one Veri*Factu record to be signed... -- <?xml version="1.0" encoding="UTF-8"?> -- <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sum="https://www2.agenciatributaria.gob.es/static_files/common/internet/dep/aplicaciones/es/aeat/tike/cont/ws/SuministroLR.xsd" xmlns:sum1="https://www2.agenciatributaria.gob.es/static_files/common/internet/dep/aplicaciones/es/aeat/tike/cont/ws/SuministroInformacion.xsd" xmlns:xd="http://www.w3.org/2000/09/xmldsig#"> -- <soapenv:Header/> -- <soapenv:Body> -- <sum:RegFactuSistemaFacturacion> -- <sum:Cabecera> -- <sum1:ObligadoEmision> -- <sum1:NombreRazon>XYZ STORE SL</sum1:NombreRazon> -- <sum1:NIF>B99999999</sum1:NIF> -- </sum1:ObligadoEmision> -- <sum1:RemisionRequerimiento> -- <sum1:RefRequerimiento>3333333333</sum1:RefRequerimiento> -- <sum1:FinRequerimiento>S</sum1:FinRequerimiento> -- </sum1:RemisionRequerimiento> -- </sum:Cabecera> -- <sum:RegistroFactura> -- <sum1:RegistroAlta Id="001-2020003408"> -- <sum1:IDVersion>1.0</sum1:IDVersion> -- <sum1:IDFactura> -- <sum1:IDEmisorFactura>89890001K</sum1:IDEmisorFactura> -- <sum1:NumSerieFactura>12345678-G66</sum1:NumSerieFactura> -- <sum1:FechaExpedicionFactura>03-02-2025</sum1:FechaExpedicionFactura> -- </sum1:IDFactura> -- <sum1:NombreRazonEmisor>certificado uno telematicas</sum1:NombreRazonEmisor> -- <sum1:Subsanacion>N</sum1:Subsanacion> -- <sum1:RechazoPrevio>N</sum1:RechazoPrevio> -- <sum1:TipoFactura>R3</sum1:TipoFactura> -- <sum1:TipoRectificativa>I</sum1:TipoRectificativa> -- <sum1:FacturasRectificadas> -- <sum1:IDFacturaRectificada> -- <sum1:IDEmisorFactura>89890001K</sum1:IDEmisorFactura> -- <sum1:NumSerieFactura>12345600-G66</sum1:NumSerieFactura> -- <sum1:FechaExpedicionFactura>01-04-2024</sum1:FechaExpedicionFactura> -- </sum1:IDFacturaRectificada> -- </sum1:FacturasRectificadas> -- <sum1:FechaOperacion>03-02-2025</sum1:FechaOperacion> -- <sum1:DescripcionOperacion>fecha entrega</sum1:DescripcionOperacion> -- <sum1:Destinatarios> -- <sum1:IDDestinatario> -- <sum1:NombreRazon>certificado dos telematicas</sum1:NombreRazon> -- <sum1:NIF>89890002E</sum1:NIF> -- </sum1:IDDestinatario> -- </sum1:Destinatarios> -- <sum1:Desglose> -- <sum1:DetalleDesglose> -- <sum1:ClaveRegimen>01</sum1:ClaveRegimen> -- <sum1:CalificacionOperacion>S1</sum1:CalificacionOperacion> -- <sum1:TipoImpositivo>4</sum1:TipoImpositivo> -- <sum1:BaseImponibleOimporteNoSujeto>10</sum1:BaseImponibleOimporteNoSujeto> -- <sum1:CuotaRepercutida>0.4</sum1:CuotaRepercutida> -- </sum1:DetalleDesglose> -- <sum1:DetalleDesglose> -- <sum1:ClaveRegimen>01</sum1:ClaveRegimen> -- <sum1:CalificacionOperacion>S1</sum1:CalificacionOperacion> -- <sum1:TipoImpositivo>21</sum1:TipoImpositivo> -- <sum1:BaseImponibleOimporteNoSujeto>100</sum1:BaseImponibleOimporteNoSujeto> -- <sum1:CuotaRepercutida>21</sum1:CuotaRepercutida> -- </sum1:DetalleDesglose> -- <sum1:DetalleDesglose> -- <sum1:ClaveRegimen>05</sum1:ClaveRegimen> -- <sum1:CalificacionOperacion>S1</sum1:CalificacionOperacion> -- <sum1:TipoImpositivo>10</sum1:TipoImpositivo> -- <sum1:BaseImponibleOimporteNoSujeto>100</sum1:BaseImponibleOimporteNoSujeto> -- <sum1:CuotaRepercutida>10</sum1:CuotaRepercutida> -- </sum1:DetalleDesglose> -- </sum1:Desglose> -- <sum1:CuotaTotal>41.4</sum1:CuotaTotal> -- <sum1:ImporteTotal>241.4</sum1:ImporteTotal> -- <sum1:Encadenamiento> -- <sum1:RegistroAnterior> -- <sum1:IDEmisorFactura>89890001K</sum1:IDEmisorFactura> -- <sum1:NumSerieFactura>12345677-G33</sum1:NumSerieFactura> -- <sum1:FechaExpedicionFactura>15-04-2024</sum1:FechaExpedicionFactura> -- <sum1:Huella>C9AF4AF1EF5EBBA700350DE3EEF12C2D355C56AC56F13DB2A25E0031BD2B7ED5</sum1:Huella> -- </sum1:RegistroAnterior> -- </sum1:Encadenamiento> -- <sum1:SistemaInformatico> -- <sum1:NombreRazon>CERTIFICADO UNO TELEMATICAS</sum1:NombreRazon> -- <sum1:NIF>89890001K</sum1:NIF> -- <sum1:NombreSistemaInformatico>NombreSistemaInformatico</sum1:NombreSistemaInformatico> -- <sum1:IdSistemaInformatico>77</sum1:IdSistemaInformatico> -- <sum1:Version>1.0.03</sum1:Version> -- <sum1:NumeroInstalacion>383</sum1:NumeroInstalacion> -- <sum1:TipoUsoPosibleSoloVerifactu>S</sum1:TipoUsoPosibleSoloVerifactu> -- <sum1:TipoUsoPosibleMultiOT>N</sum1:TipoUsoPosibleMultiOT> -- <sum1:IndicadorMultiplesOT>N</sum1:IndicadorMultiplesOT> -- </sum1:SistemaInformatico> -- <sum1:FechaHoraHusoGenRegistro>2025-02-03T14:30:00+01:00</sum1:FechaHoraHusoGenRegistro> -- <sum1:TipoHuella>01</sum1:TipoHuella> -- <sum1:Huella>FF954378B64ED331A9B2366AD317D86E9DEC1716B12DD0ACCB172A6DC4C105AA</sum1:Huella> -- </sum1:RegistroAlta> -- </sum:RegistroFactura> -- </sum:RegFactuSistemaFacturacion> -- </soapenv:Body> -- </soapenv:Envelope> DECLARE @registroAlta_id nvarchar(4000) SELECT @registroAlta_id = '001-2020003408' DECLARE @xml int EXEC @hr = sp_OACreate 'Chilkat.Xml', @xml OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END EXEC sp_OASetProperty @xml, 'Tag', 'soapenv:Envelope' EXEC sp_OAMethod @xml, 'AddAttribute', @success OUT, 'xmlns:soapenv', 'http://schemas.xmlsoap.org/soap/envelope/' EXEC sp_OAMethod @xml, 'AddAttribute', @success OUT, 'xmlns:sum', 'https://www2.agenciatributaria.gob.es/static_files/common/internet/dep/aplicaciones/es/aeat/tike/cont/ws/SuministroLR.xsd' EXEC sp_OAMethod @xml, 'AddAttribute', @success OUT, 'xmlns:sum1', 'https://www2.agenciatributaria.gob.es/static_files/common/internet/dep/aplicaciones/es/aeat/tike/cont/ws/SuministroInformacion.xsd' EXEC sp_OAMethod @xml, 'AddAttribute', @success OUT, 'xmlns:xd', 'http://www.w3.org/2000/09/xmldsig#' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Header', '' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:Cabecera|sum1:ObligadoEmision|sum1:NombreRazon', 'XYZ STORE SL' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:Cabecera|sum1:ObligadoEmision|sum1:NIF', 'B99999999' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:Cabecera|sum1:RemisionRequerimiento|sum1:RefRequerimiento', '3333333333' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:Cabecera|sum1:RemisionRequerimiento|sum1:FinRequerimiento', 'S' -- This Id is URI in the XML digital signature Reference. EXEC sp_OAMethod @xml, 'UpdateAttrAt', @success OUT, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta', 1, 'Id', @registroAlta_id EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:IDVersion', '1.0' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:IDFactura|sum1:IDEmisorFactura', '89890001K' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:IDFactura|sum1:NumSerieFactura', '12345678-G66' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:IDFactura|sum1:FechaExpedicionFactura', '03-02-2025' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:NombreRazonEmisor', 'certificado uno telematicas' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Subsanacion', 'N' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:RechazoPrevio', 'N' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:TipoFactura', 'R3' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:TipoRectificativa', 'I' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:FacturasRectificadas|sum1:IDFacturaRectificada|sum1:IDEmisorFactura', '89890001K' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:FacturasRectificadas|sum1:IDFacturaRectificada|sum1:NumSerieFactura', '12345600-G66' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:FacturasRectificadas|sum1:IDFacturaRectificada|sum1:FechaExpedicionFactura', '01-04-2024' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:FechaOperacion', '03-02-2025' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:DescripcionOperacion', 'fecha entrega' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Destinatarios|sum1:IDDestinatario|sum1:NombreRazon', 'certificado dos telematicas' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Destinatarios|sum1:IDDestinatario|sum1:NIF', '89890002E' DECLARE @i int SELECT @i = 0 EXEC sp_OASetProperty @xml, 'I', @i EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:ClaveRegimen', 01 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CalificacionOperacion', 'S1' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:TipoImpositivo', 4 EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:BaseImponibleOimporteNoSujeto', 10 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CuotaRepercutida', '0.4' SELECT @i = @i + 1 EXEC sp_OASetProperty @xml, 'I', @i EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:ClaveRegimen', 01 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CalificacionOperacion', 'S1' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:TipoImpositivo', 21 EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:BaseImponibleOimporteNoSujeto', 100 EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CuotaRepercutida', 21 SELECT @i = @i + 1 EXEC sp_OASetProperty @xml, 'I', @i EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:ClaveRegimen', 05 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CalificacionOperacion', 'S1' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:TipoImpositivo', 10 EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:BaseImponibleOimporteNoSujeto', 100 EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Desglose|sum1:DetalleDesglose[i]|sum1:CuotaRepercutida', 10 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:CuotaTotal', '41.4' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:ImporteTotal', '241.4' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Encadenamiento|sum1:RegistroAnterior|sum1:IDEmisorFactura', '89890001K' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Encadenamiento|sum1:RegistroAnterior|sum1:NumSerieFactura', '12345677-G33' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Encadenamiento|sum1:RegistroAnterior|sum1:FechaExpedicionFactura', '15-04-2024' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Encadenamiento|sum1:RegistroAnterior|sum1:Huella', 'C9AF4AF1EF5EBBA700350DE3EEF12C2D355C56AC56F13DB2A25E0031BD2B7ED5' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:NombreRazon', 'CERTIFICADO UNO TELEMATICAS' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:NIF', '89890001K' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:NombreSistemaInformatico', 'NombreSistemaInformatico' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:IdSistemaInformatico', 77 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:Version', '1.0.03' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:NumeroInstalacion', 383 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:TipoUsoPosibleSoloVerifactu', 'S' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:TipoUsoPosibleMultiOT', 'N' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:SistemaInformatico|sum1:IndicadorMultiplesOT', 'N' EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:FechaHoraHusoGenRegistro', '2025-02-03T14:30:00+01:00' EXEC sp_OAMethod @xml, 'UpdateChildContentInt', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:TipoHuella', 01 EXEC sp_OAMethod @xml, 'UpdateChildContent', NULL, 'soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta|sum1:Huella', 'FF954378B64ED331A9B2366AD317D86E9DEC1716B12DD0ACCB172A6DC4C105AA' -- Generate an ID such as "xmldsig-90637596-e368-4bd0-bcf8-d9a7be617d9a" DECLARE @sbSigId int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbSigId OUT EXEC sp_OAMethod @sbSigId, 'Append', @success OUT, 'xmldsig-' EXEC sp_OAMethod @sbSigId, 'AppendUuid', @success OUT, 1 -- Generate an ID such as "xmldsig-90637596-e368-4bd0-bcf8-d9a7be617d9a-sigvalue" DECLARE @sbSigValueId int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbSigValueId OUT EXEC sp_OAMethod @sbSigValueId, 'AppendSb', @success OUT, @sbSigId EXEC sp_OAMethod @sbSigValueId, 'Append', @success OUT, '-sigvalue' -- Generate an ID such as "xmldsig-90637596-e368-4bd0-bcf8-d9a7be617d9a-signedprops" DECLARE @sbSignedPropsId int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbSignedPropsId OUT EXEC sp_OAMethod @sbSignedPropsId, 'AppendSb', @success OUT, @sbSigId EXEC sp_OAMethod @sbSignedPropsId, 'Append', @success OUT, '-signedprops' -- Generate an ID such as "xmldsig-90637596-e368-4bd0-bcf8-d9a7be617d9a-ref0" DECLARE @sbObjectRefId int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbObjectRefId OUT EXEC sp_OAMethod @sbObjectRefId, 'AppendSb', @success OUT, @sbSigId EXEC sp_OAMethod @sbObjectRefId, 'Append', @success OUT, '-ref0' DECLARE @gen int EXEC @hr = sp_OACreate 'Chilkat.XmlDSigGen', @gen OUT EXEC sp_OASetProperty @gen, 'SigLocation', 'soapenv:Envelope|soapenv:Body|sum:RegFactuSistemaFacturacion|sum:RegistroFactura|sum1:RegistroAlta' EXEC sp_OASetProperty @gen, 'SigLocationMod', 0 EXEC sp_OAMethod @sbSigId, 'GetAsString', @sTmp0 OUT EXEC sp_OASetProperty @gen, 'SigId', @sTmp0 EXEC sp_OASetProperty @gen, 'SigNamespacePrefix', 'ds' EXEC sp_OASetProperty @gen, 'SigNamespaceUri', 'http://www.w3.org/2000/09/xmldsig#' EXEC sp_OAMethod @sbSigValueId, 'GetAsString', @sTmp0 OUT EXEC sp_OASetProperty @gen, 'SigValueId', @sTmp0 EXEC sp_OASetProperty @gen, 'SignedInfoCanonAlg', 'C14N' EXEC sp_OASetProperty @gen, 'SignedInfoDigestMethod', 'sha256' -- Create an Object to be added to the Signature. DECLARE @object1 int EXEC @hr = sp_OACreate 'Chilkat.Xml', @object1 OUT EXEC sp_OASetProperty @object1, 'Tag', 'xades:QualifyingProperties' EXEC sp_OAMethod @object1, 'AddAttribute', @success OUT, 'xmlns:xades', 'http://uri.etsi.org/01903/v1.3.2#' EXEC sp_OAMethod @object1, 'AddAttribute', @success OUT, 'xmlns:xades141', 'http://uri.etsi.org/01903/v1.4.1#' -- "#xmldsig-90637596-e368-4bd0-bcf8-d9a7be617d9a" EXEC sp_OAMethod @sbSigId, 'Prepend', @success OUT, '#' EXEC sp_OAMethod @sbSigId, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @object1, 'AddAttribute', @success OUT, 'Target', @sTmp0 EXEC sp_OAMethod @sbSignedPropsId, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties', 1, 'Id', @sTmp0 EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningTime', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:CertDigest|ds:DigestMethod', 1, 'Algorithm', 'http://www.w3.org/2000/09/xmldsig#sha1' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:CertDigest|ds:DigestValue', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:IssuerSerial|ds:X509IssuerName', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:IssuerSerial|ds:X509SerialNumber', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[1]|xades:CertDigest|ds:DigestMethod', 1, 'Algorithm', 'http://www.w3.org/2000/09/xmldsig#sha1' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[1]|xades:CertDigest|ds:DigestValue', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[1]|xades:IssuerSerial|ds:X509IssuerName', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[1]|xades:IssuerSerial|ds:X509SerialNumber', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[2]|xades:CertDigest|ds:DigestMethod', 1, 'Algorithm', 'http://www.w3.org/2000/09/xmldsig#sha1' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[2]|xades:CertDigest|ds:DigestValue', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[2]|xades:IssuerSerial|ds:X509IssuerName', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert[2]|xades:IssuerSerial|ds:X509SerialNumber', 'TO BE GENERATED BY CHILKAT' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SignaturePolicyIdentifier|xades:SignaturePolicyId|xades:SigPolicyId|xades:Identifier', 'urn:oid:2.16.724.1.3.1.1.2.1.9' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SignaturePolicyIdentifier|xades:SignaturePolicyId|xades:SigPolicyId|xades:Description', '' EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SignaturePolicyIdentifier|xades:SignaturePolicyId|xades:SigPolicyHash|ds:DigestMethod', 1, 'Algorithm', 'http://www.w3.org/2000/09/xmldsig#sha1' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SignaturePolicyIdentifier|xades:SignaturePolicyId|xades:SigPolicyHash|ds:DigestValue', 'G7roucf600+f03r/o0bAOQ6WAs0=' EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedSignatureProperties|xades:SignaturePolicyIdentifier|xades:SignaturePolicyId|xades:SigPolicyQualifiers|xades:SigPolicyQualifier|xades:SPURI', 'https://sede.administracion.gob.es/politica_de_firma_anexo_1.pdf' EXEC sp_OAMethod @sbObjectRefId, 'Prepend', @success OUT, '#' EXEC sp_OAMethod @sbObjectRefId, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @object1, 'UpdateAttrAt', @success OUT, 'xades:SignedProperties|xades:SignedDataObjectProperties|xades:DataObjectFormat', 1, 'ObjectReference', @sTmp0 EXEC sp_OAMethod @object1, 'UpdateChildContent', NULL, 'xades:SignedProperties|xades:SignedDataObjectProperties|xades:DataObjectFormat|xades:MimeType', 'text/xml' EXEC sp_OAMethod @object1, 'GetXml', @sTmp0 OUT EXEC sp_OAMethod @gen, 'AddObject', @success OUT, '', @sTmp0, '', '' -- -------- Reference 1 -------- -- The URI for this Reference is the registroAlta_id EXEC sp_OAMethod @gen, 'AddSameDocRef', @success OUT, @registroAlta_id, 'sha256', '', '', '' -- Remove the "#" EXEC sp_OAMethod @sbObjectRefId, 'RemoveCharsAt', @success OUT, 0, 1 EXEC sp_OAMethod @sbObjectRefId, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @gen, 'SetRefIdAttr', @success OUT, @registroAlta_id, @sTmp0 -- -------- Reference 2 -------- EXEC sp_OAMethod @sbSignedPropsId, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @gen, 'AddObjectRef', @success OUT, @sTmp0, 'sha256', 'C14N', '', 'http://uri.etsi.org/01903#SignedProperties' -- Provide a certificate + private key. (PFX password is test123) DECLARE @cert int EXEC @hr = sp_OACreate 'Chilkat.Cert', @cert OUT EXEC sp_OAMethod @cert, 'LoadPfxFile', @success OUT, 'qa_data/pfx/cert_test123.pfx', 'test123' IF @success = 0 BEGIN EXEC sp_OAGetProperty @cert, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml EXEC @hr = sp_OADestroy @sbSigId EXEC @hr = sp_OADestroy @sbSigValueId EXEC @hr = sp_OADestroy @sbSignedPropsId EXEC @hr = sp_OADestroy @sbObjectRefId EXEC @hr = sp_OADestroy @gen EXEC @hr = sp_OADestroy @object1 EXEC @hr = sp_OADestroy @cert RETURN END EXEC sp_OAMethod @gen, 'SetX509Cert', @success OUT, @cert, 1 EXEC sp_OASetProperty @gen, 'KeyInfoType', 'X509Data+KeyValue' EXEC sp_OASetProperty @gen, 'X509Type', 'Certificate' -- Load XML to be signed... DECLARE @sbXml int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbXml OUT EXEC sp_OAMethod @xml, 'GetXmlSb', @success OUT, @sbXml EXEC sp_OASetProperty @gen, 'Behaviors', 'IndentedSignature,Base64Cr13Entity' -- Sign the XML... EXEC sp_OAMethod @gen, 'CreateXmlDSigSb', @success OUT, @sbXml IF @success = 0 BEGIN EXEC sp_OAGetProperty @gen, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml EXEC @hr = sp_OADestroy @sbSigId EXEC @hr = sp_OADestroy @sbSigValueId EXEC @hr = sp_OADestroy @sbSignedPropsId EXEC @hr = sp_OADestroy @sbObjectRefId EXEC @hr = sp_OADestroy @gen EXEC @hr = sp_OADestroy @object1 EXEC @hr = sp_OADestroy @cert EXEC @hr = sp_OADestroy @sbXml RETURN END -- ----------------------------------------------- -- Save the signed XML to a file. EXEC sp_OAMethod @sbXml, 'WriteFile', @success OUT, 'c:/temp/qa_output/signedSoapXml1.xml', 'utf-8', 0 EXEC sp_OAMethod @sbXml, 'GetAsString', @sTmp0 OUT PRINT @sTmp0 -- ---------------------------------------- -- Verify the signatures we just produced... DECLARE @verifier int EXEC @hr = sp_OACreate 'Chilkat.XmlDSig', @verifier OUT EXEC sp_OAMethod @verifier, 'LoadSignatureSb', @success OUT, @sbXml IF @success = 0 BEGIN EXEC sp_OAGetProperty @verifier, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml EXEC @hr = sp_OADestroy @sbSigId EXEC @hr = sp_OADestroy @sbSigValueId EXEC @hr = sp_OADestroy @sbSignedPropsId EXEC @hr = sp_OADestroy @sbObjectRefId EXEC @hr = sp_OADestroy @gen EXEC @hr = sp_OADestroy @object1 EXEC @hr = sp_OADestroy @cert EXEC @hr = sp_OADestroy @sbXml EXEC @hr = sp_OADestroy @verifier RETURN END DECLARE @numSigs int EXEC sp_OAGetProperty @verifier, 'NumSignatures', @numSigs OUT DECLARE @verifyIdx int SELECT @verifyIdx = 0 WHILE @verifyIdx < @numSigs BEGIN EXEC sp_OASetProperty @verifier, 'Selector', @verifyIdx DECLARE @verified int EXEC sp_OAMethod @verifier, 'VerifySignature', @verified OUT, 1 IF @verified <> 1 BEGIN EXEC sp_OAGetProperty @verifier, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml EXEC @hr = sp_OADestroy @sbSigId EXEC @hr = sp_OADestroy @sbSigValueId EXEC @hr = sp_OADestroy @sbSignedPropsId EXEC @hr = sp_OADestroy @sbObjectRefId EXEC @hr = sp_OADestroy @gen EXEC @hr = sp_OADestroy @object1 EXEC @hr = sp_OADestroy @cert EXEC @hr = sp_OADestroy @sbXml EXEC @hr = sp_OADestroy @verifier RETURN END SELECT @verifyIdx = @verifyIdx + 1 END PRINT 'All signatures were successfully verified.' EXEC @hr = sp_OADestroy @xml EXEC @hr = sp_OADestroy @sbSigId EXEC @hr = sp_OADestroy @sbSigValueId EXEC @hr = sp_OADestroy @sbSignedPropsId EXEC @hr = sp_OADestroy @sbObjectRefId EXEC @hr = sp_OADestroy @gen EXEC @hr = sp_OADestroy @object1 EXEC @hr = sp_OADestroy @cert EXEC @hr = sp_OADestroy @sbXml EXEC @hr = sp_OADestroy @verifier END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.