Sample code for 30+ languages & platforms
PHP ActiveX

hacienda.go.cr Recepción de comprobantes electrónicos y respuestas del receptor.

See more hacienda.go.cr Examples

Comprobantes Electrónicos API version v1 -- Recepción de comprobantes electrónicos y respuestas del receptor.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$http = new COM("Chilkat.Http");

// Implements the following CURL command:

// curl -X POST -H "Content-Type: application / json" \
//   -H 'authorization: Bearer {access_token}' \
//   -d '{
//   "clave": "50601011600310112345600100010100000000011999999999",
//   "fecha": "2016-01-01T00:00:00-0600",
//   "emisor": {
//     "tipoIdentificacion": "02",
//     "numeroIdentificacion": "003101123456"
//   },
//   "receptor": {
//     "tipoIdentificacion": "02",
//     "numeroIdentificacion": "003101123456"
//   },
//   "comprobanteXml": "PD94..."
// }' https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion

// Use the following online tool to generate HTTP code from a CURL command
// Convert a cURL Command to HTTP Source Code

// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON

// The following JSON is sent in the request body.

// {
//   "clave": "50601011600310112345600100010100000000011999999999",
//   "fecha": "2016-01-01T00:00:00-0600",
//   "emisor": {
//     "tipoIdentificacion": "02",
//     "numeroIdentificacion": "003101123456"
//   },
//   "receptor": {
//     "tipoIdentificacion": "02",
//     "numeroIdentificacion": "003101123456"
//   },
//   "comprobanteXml": "PD94b..."
// }

// Load the previously signed XML.
$bdSignedXml = new COM("Chilkat.BinData");
$success = $bdSignedXml->LoadFile('someDir/signed.xml');
if ($success == 0) {
    print 'Failed to load the XAdES signed XML.' . "\n";
    exit;
}

$json = new COM("Chilkat.JsonObject");
$json->UpdateString('clave','50601011600310112345600100010100000000011999999999');
$json->UpdateString('fecha','2016-01-01T00:00:00-0600');
$json->UpdateString('emisor.tipoIdentificacion','02');
$json->UpdateString('emisor.numeroIdentificacion','003101123456');
$json->UpdateString('receptor.tipoIdentificacion','02');
$json->UpdateString('receptor.numeroIdentificacion','003101123456');
// Add the base64 encoded representation of the signed XML.
$json->UpdateString('comprobanteXml',$bdSignedXml->getEncoded('base64'));

// Load our previously obtained OAuth2 access token.
$jsonToken = new COM("Chilkat.JsonObject");
$success = $jsonToken->LoadFile('qa_data/tokens/hacienda_cr.json');
if ($success != 1) {
    print 'Failed to load constantContact.json' . "\n";
    exit;
}

// Adds the "Authorization: Bearer {access_token}" header.
$http->AuthToken = $jsonToken->stringOf('access_token');

$http->SetRequestHeader('Content-Type','application / json');

$resp = new COM("Chilkat.HttpResponse");
$success = $http->HttpJson('POST','https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion',$json,'application/json',$resp);
if ($success == 0) {
    print $http->LastErrorText . "\n";
    exit;
}

// A 201 status code indicates success.
print 'Response status code: ' . $resp->StatusCode . "\n";

print 'Response body:' . "\n";
print $resp->BodyStr . "\n";

?>