Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Classic ASP) SII POST boleta.electronica.tokenObtener un token de at autenticación para el envío y consultas automatizadas de boletas electrónicas. For more information, see https://www4c.sii.cl/bolcoreinternetui/api/
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <% ' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Create the XML to be signed... ' The following XML is created: ' ' <?xml version="1.0" encoding="UTF-8"?> ' <getToken><item><Semilla>030530912644</Semilla></item></getToken> ' set xmlToSign = Server.CreateObject("Chilkat_9_5_0.Xml") xmlToSign.Tag = "getToken" xmlToSign.UpdateChildContent "item|Semilla","030530912644" ' Sign the XML. ' ' We wish to create the following signed XML: ' <?xml version="1.0" encoding="UTF-8"?> ' <getToken> ' <item> ' <Semilla>030530912644</Semilla> ' </item> ' <Signature xmlns="http://www.w3.org/2000/09/xmldsig#"> ' <SignedInfo> ' <CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"> ' </CanonicalizationMethod> ' <SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"> ' </SignatureMethod> ' <Reference URI=""> ' <Transforms> ' <Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"> ' </Transform> ' </Transforms> ' <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"> ' </DigestMethod> ' <DigestValue>l2s9BqLppHaWo+w1Al1J5SsYScs=</DigestValue> ' </Reference> ' </SignedInfo> ' <SignatureValue>jlbzatIIBLW8AjH++5uVTTrGIMVwGButuoAR88y/hvSc1+6/eW1K864fK3cKi76oArqk7lAM4pP okoXme0JT/hRXXGo6ecuKzO18z2WfPWwgnN0f3ac03TDu7PwfqiDG9mhQpYfIkNp6GNJIiqlg9PG2w1fOJ1QoypsrQmKq6 YU=</SignatureValue> ' <KeyInfo> ' <KeyValue> ' <RSAKeyValue> ' <Modulus>2Pb4kEB19m7NmOUYew9f36325yrTLTPMU7qzYG2A0/BsubxDdgQw2Op0x6zXvOVX sYI9KkPXtD5orKJMjwxYRv9wUWdyiE776Rv4ljfJO7EQhIK1fDQDnPt0HefBS06Xzg2QLBvLR+pe1vc6C02Dr99v+lnLA8 mnZiJlRHndhNU=</Modulus> ' <Exponent>AQAB</Exponent> ' </RSAKeyValue> ' </KeyValue> ' <X509Data> ' <X509Certificate>MIIF1DCCBLygAwIBAgIDAQNtMA0GCSqGSIb3DQEBBQUAMIHGMQswCQYDVQQG ' EwJDTDEYMBYGA1UEChMPQWNlcHRhLmNvbSBTLkEuMTgwNgYDVQQLEy9BdXRv ' cmlkYWQgY2VydGlmaWNhZG9yYSBDbGFzZSAzIHBlcnNvbmEgbmF0dXJhbDFD ' MEEGA1UEAxM6QWNlcHRhLmNvbSBBdXRvcmlkYWQgY2VydGlmaWNhZG9yYSBD ' bGFzZSAzIHBlcnNvbmEgbmF0dXJhbDEeMBwGCSqGSIb3DQEJARYPaW5mb0Bh ' Y2VwdGEuY29tMB4XDTAxMDkyNTIxMDgxMloXDTAyMDkyNTIxMDgxMlowgZ8x ' CzAJBgNVBAYTAkNMMRgwFgYDVQQKEw9BY2VwdGEuY29tIFMuQS4xLDAqBgNV ' BAsTI0NlcnRpZmljYWRvIENsYXNlIDMgUGVyc29uYSBOYXR1cmFsMRwwGgYJ ' KoZIhvcNAQkBFg1uY2hlbGVAc2lpLmNsMSowKAYDVQQDEyFOSUNPTEFTIFpB ' UFJJQU4gQ0hFTEVCSUZTS0kgQkFFWkEwgZ8wDQYJKoZIhvcNAQEBBQADgY0A ' MIGJAoGBANj2+JBAdfZuzZjlGHsPX9+t9ucq0y0zzFO6s2BtgNPwbLm8Q3YE ' MNjqdMes17zlV7GCPSpD17Q+aKyiTI8MWEb/cFFncohO++kb+JY3yTuxEISC ' tXw0A5z7dB3nwUtOl84NkCwby0fqXtb3OgtNg6/fb/pZywPJp2YiZUR53YTV ' AgMBAAGjggJyMIICbjAdBggrBgEEAbVrDwQRFg9BY2VwdGEuY29tIFMuQS4w ' JQYDVR0RBB4wHKAaBggrBgEEAcEBAaAOFgwxMC40MTEuODcxLTIwDwYIKwYB ' Jh0z1DR3Pl3xOiaFIjSXsQO2PSzcA3wZXYF+KDrMul8e5lAF2NNiLmMVtXEx ' ZykMaTGGWS0ZETDhJmBwEZGpP4+lt/JhgwF1Sb6wdrXp7MFCJUc1Tj+/5JqH ' 1kP0E63/hVElrcP0g8Zn8Z+vr/PMGW1kKgE0IyS4iJ8eIhNSK5phFyKJUn0l ' BmIZX7u89d5u7X8= ' </X509Certificate> ' </X509Data> ' </KeyInfo> ' </Signature> ' </getToken> set gen = Server.CreateObject("Chilkat_9_5_0.XmlDSigGen") gen.SigLocation = "getToken" gen.SigLocationMod = 0 gen.SigNamespacePrefix = "" gen.SigNamespaceUri = "http://www.w3.org/2000/09/xmldsig#" gen.SignedInfoCanonAlg = "C14N" gen.SignedInfoDigestMethod = "sha1" ' -------- Reference 1 -------- success = gen.AddSameDocRef("","sha1","","","") ' Provide a certificate + private key. (PFX password is test123) set cert = Server.CreateObject("Chilkat_9_5_0.Cert") success = cert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123") If (success <> 1) Then Response.Write "<pre>" & Server.HTMLEncode( cert.LastErrorText) & "</pre>" Response.End End If success = gen.SetX509Cert(cert,1) gen.KeyInfoType = "X509Data+KeyValue" gen.X509Type = "Certificate" ' Load XML to be signed... set sbXml = Server.CreateObject("Chilkat_9_5_0.StringBuilder") success = xmlToSign.GetXmlSb(sbXml) gen.Behaviors = "IndentedSignature" ' Sign the XML... success = gen.CreateXmlDSigSb(sbXml) If (success <> 1) Then Response.Write "<pre>" & Server.HTMLEncode( gen.LastErrorText) & "</pre>" Response.End End If Response.Write "<pre>" & Server.HTMLEncode( sbXml.GetAsString()) & "</pre>" ' Send the POST with signed XML in the request body set http = Server.CreateObject("Chilkat_9_5_0.Http") http.SetRequestHeader "accept","application/xml" ' Use one of the following domains, depending on the environment: ' apicert.sii.cl - Certification Environment ' api.sii.cl - Production Environment url = "https://apicert.sii.cl/recursos/v1/boleta.electronica.token" ' resp is a Chilkat_9_5_0.HttpResponse Set resp = http.PostXml(url,sbXml.GetAsString(),"utf-8") If (http.LastMethodSuccess <> 1) Then Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>" Response.End End If ' Examine the response status code: Response.Write "<pre>" & Server.HTMLEncode( "response status code = " & resp.StatusCode) & "</pre>" ' Examine the response body: Response.Write "<pre>" & Server.HTMLEncode( "response body: " & resp.BodyStr) & "</pre>" ' We expect a response like this: ' <?xml version="1.0" encoding="UTF-8"?> ' <SII:RESPUESTA xmlns:SII="http://www.sii.cl/XMLSchema"> ' <SII:RESP_HDR> ' <ESTADO>00</ESTADO> ' <GLOSA>Token Creado</GLOSA> ' </SII:RESP_HDR> ' <SII:RESP_BODY> ' <TOKEN>XAuSbYXiNh9Ik</TOKEN> ' </SII:RESP_BODY> ' </SII:RESPUESTA> ' Parse the XML response. set xml = Server.CreateObject("Chilkat_9_5_0.Xml") success = xml.LoadXml(resp.BodyStr) ESTADO = xml.GetChildIntValue("SII:RESP_HDR|ESTADO") GLOSA = xml.GetChildContent("SII:RESP_HDR|GLOSA") TOKEN = xml.GetChildContent("SII:RESP_BODY|TOKEN") %> </body> </html> |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.