Sample code for 30+ languages & platforms
Classic ASP

SII POST boleta.electronica.token

See more SII Chile Examples

Obtener un token de at autenticación para el envío y consultas automatizadas de boletas electrónicas.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

' 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.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.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.Cert")
success = cert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123")
If (success = 0) 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.StringBuilder")
success = xmlToSign.GetXmlSb(sbXml)

gen.Behaviors = "IndentedSignature"

' Sign the XML...
success = gen.CreateXmlDSigSb(sbXml)
If (success = 0) 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.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"
set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpSb("POST",url,sbXml,"utf-8","application/xml",resp)
If (success = 0) 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.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>