The Node.js SDK for Australia Passport OCR

Achieve 99.8%+ accuracy and sub-second latency for parsing Australian passports and ICAO 9303 compliant MRZ data, handling intricate security backgrounds with ease.

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

Why Australian Passport OCR is Difficult in Node.js

Building a reliable passport OCR pipeline from scratch is non-trivial for Australian documents. While the Australian passport data page is entirely in English, it incorporates some of the world's most advanced security features. Intricate offset printing, microtext, and full-color guilloche patterns heavily interfere with standard Node.js wrappers like Tesseract, causing background noise to be misread as characters. Additionally, lengthy multi-part given names and hyphenated surnames frequently cause segmentation errors in generic OCR tools. Developing custom RegEx patterns in JavaScript to parse the Machine Readable Zone (MRZ) while ignoring these security artifacts 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 Oceanian identity documents and the robust security designs of the Australian passport. 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 Australian 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 Sydney Kingsford Smith Airport (SYD) and Melbourne Airport (MEL).
  • Financial Compliance: Ensure strict compliance with AUSTRAC and regional 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 Australian passport extraction. It handles the file buffer and parses both MRZ and visual fields, accurately capturing multi-part names and ignoring complex security backgrounds.

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 scanAustraliaPassport() {
  // Note: Supports JPG, PNG, WebP (Max 4.5MB)
  const imagePath = './australia_passport_sample.jpg';

  try {
    console.log(`Processing Australia 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);
  }
}

scanAustraliaPassport();

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

  • Security Background Rejection: Accurately extracts text without being confused by microtext, offset patterns, or intricate guilloche designs that disrupt standard OCR engines.
  • Multi-Part Name Handling: Correctly parses lengthy given names and hyphenated surnames without segmentation errors in your Node environment.
  • 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 Australian passport.

{
  "success": true,
  "data": {
    "type": "passport",
    "country_code": "AUS",
    "nationality": "AUS",
    "passport_number": "N1234567",
    "surname": "SMITH",
    "given_names": "JOHN WILLIAM",
    "sex": "M",
    "date_of_birth": "1990-03-15",
    "place_of_birth": "SYDNEY",
    "date_of_issue": "2023-06-10",
    "date_of_expiry": "2028-06-09",
    "issuing_authority": "AUSTRALIAN PASSPORT OFFICE"
  }
}

Frequently Asked Questions

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

Generic OCR services often struggle with the complex security backgrounds of Australian passports, frequently misreading artifacts as characters or missing fields entirely. Furthermore, you remain responsible for writing JavaScript parsing logic and validating MRZ checksums. StructOCR is a specialized API trained specifically on these Oceanian 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