The Node.js SDK for Argentina Passport OCR

Achieve 99.8%+ accuracy and sub-second latency for parsing bilingual (Spanish/English) Argentine passports and ICAO 9303 compliant MRZ data.

A diagram showing an Argentine passport image processed by the StructOCR Node.js API, returning structured JSON.
Figure 1: StructOCR converts raw Argentina Passport images into validated JSON data natively in your Node.js backend.

Why Argentine Passport OCR is Difficult in Node.js

Building a reliable passport OCR pipeline from scratch is non-trivial for Argentine documents. The Argentine passport features a bilingual layout, combining Spanish and English text on the same data page. Spanish uses accented characters such as á, é, í, ó, ú, ü, and the distinctive ñ, which frequently cause misinterpretation in standard Node.js wrappers like Tesseract, leading to character corruption and field misalignment. Furthermore, the documents incorporate intricate security backgrounds, guilloche patterns, and the Sol de Mayo emblem that introduce optical noise. Developing custom RegEx patterns in JavaScript to parse the Machine Readable Zone (MRZ) while correcting these bilingual and accented-character alignment issues is highly brittle, often resulting in high manual review rates.

Enterprise-Grade Extraction with the StructOCR SDK

StructOCR simplifies document processing in your JavaScript ecosystem by replacing complex pipelines with a single async API call. Our service leverages pre-trained Deep Learning models optimized specifically for Latin American identity documents and the complexities of Spanish/English bilingual typography. Our passport mrz ocr api automatically handles perspective correction, denoising, and glare removal. Instead of returning raw, unstructured text strings, the StructOCR Node.js SDK provides standardized JSON output with validated fields. This capability is crucial for applications managing international borders, as it eliminates the need for manual parsing, delivering production-ready data directly to your Express, NestJS, or Next.js applications.

Production Use Cases

  • Digital Onboarding (e-KYC): Reduce drop-off rates by pre-filling user data from Argentine Passports into your fintech or digital services apps in under 2 seconds.
  • Travel & Aviation Apps: Seamlessly integrate with Node.js backends for automated check-in systems and border management at hubs like Ministro Pistarini International Airport (EZE) and Aeroparque Jorge Newbery (AEP) in Buenos Aires.
  • Financial Compliance: Ensure strict compliance with the Central Bank of Argentina (BCRA) and Unidad de Información Financiera (UIF) Anti-Money Laundering (AML) regulations by automatically and accurately verifying identity documents.

Live Demo: Passport scanner

No registration required. Upload a file to test the extraction.

1
Upload
2
Results

Drop files here or click to browse

JPG · PNG · WebP  ·  up to 500 files · max 4.5 MB each

No files selected

Ready to use this in production? Get 20 free API calls — no credit card needed.

Get 20 Free API Calls →

Implementation: Node.js SDK

The official Node.js SDK simplifies Argentine passport extraction. It handles the file buffer and parses both MRZ and visual fields containing bilingual Spanish and English text, including special characters like á, é, í, ó, ú, ü, ñ.

Prerequisite: npm install structocr

CODE EXAMPLE
const StructOCR = require('structocr');

// 💰 Save 30%+ vs competitors. Get 20 free credits instantly:
// 👉 https://structocr.com/register
// Initialize the client with your API key
const client = new StructOCR('YOUR_API_KEY_HERE');

async function scanArgentinaPassport() {
  // Note: Supports JPG, PNG, WebP (Max 4.5MB)
  const imagePath = './argentina_passport_sample.jpg';

  try {
    console.log(`Processing Argentina passport: ${imagePath}...`);

    // The SDK handles file reading and the API call seamlessly
    const result = await client.scanPassport(imagePath);

    if (result.success && result.data) {
      const data = result.data;
      console.log('✅ Extraction Successful!');
      
      // Basic Identity (MRZ + VIZ)
      console.log(`Passport #: ${data.passport_number}`);
      console.log(`Name:       ${data.surname} ${data.given_names}`);
      console.log(`Nation:     ${data.nationality} (${data.country_code})`);
      
      // Visual Zone Specifics
      console.log(`Birth Place:${data.place_of_birth}`);
      console.log(`Authority:  ${data.issuing_authority}`);
      
      // Dates
      console.log(`DOB:        ${data.date_of_birth} (${data.sex})`);
      console.log(`Expiry:     ${data.date_of_expiry}`);

    } else {
      console.error('❌ Extraction Failed:', result.error || 'Unknown Error');
    }
  } catch (error) {
    console.error('An unexpected error occurred:', error.message);
  }
}

scanArgentinaPassport();

Technical Specs

  • Latency: < 5s (Average)
  • Uptime: 98.5% SLA
  • Security: AES-256 Encryption & SOC2 Compliant
  • Input: JPG, PNG, WebP (File Path or Buffer)
  • Max File Size: 4.5MB
  • Output: JSON (Structured Data)

Key Features

  • Spanish Character Support: Accurately parses names and places containing accented characters such as á, é, í, ó, ú, ü, and ñ, without character corruption or alignment errors in your Node environment.
  • Visual Extraction (VIZ): Reliably extracts data directly from the visual inspection zone, bypassing intricate national security backgrounds and the Sol de Mayo watermark.
  • Date Normalization: Returns all dates (Birth, Issue, Expiry) in a standardized YYYY-MM-DD format, ready for JavaScript `Date` objects.

Sample JSON Output

StructOCR returns a normalized JSON object, automatically managing character encodings and structuring the data extracted from the Argentine passport.

{
  "success": true,
  "data": {
    "type": "passport",
    "country_code": "ARG",
    "nationality": "ARG",
    "passport_number": "A12345678",
    "surname": "GONZÁLEZ",
    "given_names": "JUAN CARLOS",
    "sex": "M",
    "date_of_birth": "1993-10-12",
    "place_of_birth": "BUENOS AIRES",
    "date_of_issue": "2023-04-05",
    "date_of_expiry": "2028-04-04",
    "issuing_authority": "REGISTRO NACIONAL DE LAS PERSONAS"
  }
}

Frequently Asked Questions

How does StructOCR compare to AWS Textract or Google Vision for Argentine documents?

Generic OCR services often struggle with the Spanish/English bilingual layout and special accented characters (á, é, í, ó, ú, ü, ñ) prevalent in Argentine passports, frequently misreading or omitting them. Furthermore, you remain responsible for writing JavaScript parsing logic and validating MRZ checksums. StructOCR is a specialized API trained specifically on these Latin American documents, returning validated, labeled fields directly.

Do you store the uploaded images?

We do not store customer images. All data is processed in-memory (RAM) and is purged immediately after the API request is completed. We are a SOC2 compliant provider.

Can I pass a buffer instead of a file path in Node.js?

Yes, our Node.js SDK fully supports passing image Buffers directly, which is ideal for serverless environments like AWS Lambda or Cloudflare Workers where you might not want to write files to disk.

More OCR Tutorials

Precise Data Extraction and Seamless Integration with AI-powered OCR API.

Empower your solutions with automated data extraction by integrating best-in class StructOCR via API seamlessly.

No credit card required • Full API access included