From the creators of Abundera Sign

Free EMVCo Merchant QR Code Generator

Build EMVCo MPM compliant QR codes for any merchant scheme — the underlying standard for PIX, PromptPay, JPQR, UnionPay, Singapore SGQR, and dozens more.

0 / 900

Local uploads stay in your browser and only appear on the printed card. The QR data uses the URL above.

More fields (optional)

Address

Social profiles

Tip: right-click any spot on Google Maps and copy the coordinates

A red Swiss flag is automatically overlaid on the QR — required by Swiss banks.

Paste a BOLT11 invoice (lnbc...) or a Lightning address. We prefix with the lightning: URI scheme so any Lightning wallet can scan it.

Compatible with Google Authenticator, Authy, 1Password, Bitwarden, and any standard TOTP app.

Encodes the entire authorized_keys line. Scan to copy/paste the key onto a new machine.

For very long keys, use rMQR landscape or split into multiple QRs. Standard QR caps around ~2KB.

The official WireGuard mobile apps scan these directly. Never include your private key in a printed QR — only digital sharing.

GS1 Digital Link is the modern web-friendly alternative to the EAN-13 barcode for retail products. Resolver domain defaults to id.gs1.org but you can use your own.

Paste the share link from the Spotify app, or just the ID. We build the open.spotify.com URL automatically.

Format depends on platform — for Mastodon use @user@instance, for Bluesky use handle.bsky.social, for Nostr paste the npub key.

Geo URI (RFC 5870) opens directly in any maps app on the device — Google Maps, Apple Maps, OsmAnd, etc. — without picking a vendor.

Standard BitTorrent magnet link. Scanned by any BitTorrent client that supports URI scheme handlers.

Paste a full RFC 5545 iCalendar payload — supports multiple events, alarms, recurring rules. Most calendar apps import the QR directly.

Local uploads stay in your browser and only appear on the printed card. MeCard QR data has no photo field.

MeCard is a simpler alternative to vCard, preferred by some Android devices

More fields (optional)

Address

0 chars

Micro QR capacity: 35 digits, 21 uppercase alphanumeric, or ~15 bytes (lowercase/URLs). Best for short codes, serial numbers, and IDs. For URLs, use standard QR instead.

Most phone cameras cannot scan Micro QR codes. This format requires specialized industrial scanners (e.g. Scandit, Cognex). Use standard QR for general-purpose scanning.

Rectangular Micro QR — a narrow, wide format ideal for test tubes, wristbands, and ticket strips. Up to 361 characters.

Most phone cameras cannot scan rMQR codes. This format requires specialized industrial scanners. Use standard QR for general-purpose scanning.
Show 30 more templates

Save a style with the button above to keep your favourites here.

#000000
#FFFFFF

Or pick a built-in icon:

Renders behind the QR at reduced opacity. Auto-forces EC=H so the QR still scans through the photo.

Batch Generation

Upload a CSV to generate up to 500 QR codes in a single batch. Each row becomes its own QR — pick a template or override 21 properties on a per-row basis: colors, frames, dot/eye/eyeball styles, gradients, transparency, size, error correction, format, built-in logo, and more.

21 columns: type, data, filename, frametext, frame, template, fgcolor, bgcolor, size, ec, dotstyle, eyestyle, format, logo, gradient, g2, gtype, gangle, transparent, eyeball, eyecolor. Only type and data are required. Use | to separate fields inside data (e.g. ssid|password|WPA).

All 20 QR types supported, including URL, WiFi, vCard, MeCard, Email, SMS, Event, Location, UPI, SEPA, PayPal, Crypto, Micro QR and rMQR. Download the sample CSV to see every column, all 40 templates, 11 frame styles, and the 12 built-in logos in action.

Save the entire QR — type, all field values, style, frame, logo, business card design — as a single .qr.json file. Load it later to recreate everything in one click.

Ctrl+D Download PNG
Ctrl+Shift+D Download SVG
Ctrl+Shift+C Copy QR
Ctrl+P Print

Enter content to generate your QR code

Also by Abundera

E-signatures that hold up in court

Abundera Sign goes beyond basic e-signatures. Every document gets cryptographic proof, independent verification, and a tamper-evident evidence package.

  • Auto-generated court-ready evidence packages
  • Personal Document Seal — detects tampering instantly
  • Anchored to 5 independent systems — no single point of failure
Try Abundera Sign

What is EMVCo MPM?

EMVCo is the consortium of Visa, Mastercard, JCB, American Express, China UnionPay, and Discover that defines the technical standards for chip cards, contactless, tokenization, and (since 2017) merchant QR codes. The Merchant-Presented Mode QR specification is the format every national payment scheme builds on top of — including Brazil's PIX, Thailand's PromptPay, India's UPI, Singapore's SGQR, Japan's JPQR, China UnionPay QuickPass, Hong Kong FPS, and Malaysia's DuitNow.

The payload is a TLV (Tag-Length-Value) string with mandatory fields for payload format, point of initiation, merchant category, currency, country, name, city, and a CRC-16/CCITT-FALSE checksum at the end. Each national scheme adds an Application Identifier (AID) inside one of the 26-51 merchant account templates.

This generic builder is for cases where you need to mint an EMVCo MPM QR for a scheme we don't have a dedicated UI for. Pick the AID, set the MCC, currency, country, and merchant name — we handle TLV encoding and CRC.

Frequently Asked Questions

What's the AID?

The Application Identifier — a hex string that identifies which payment scheme the QR is for. Each national scheme registers its own AID with EMVCo. Examples: PIX = 'br.gov.bcb.pix' (note: BR uses a reverse-DNS string instead of a hex AID), PromptPay = 'A000000677010111', JPQR = 'jp.or.paymentsjapan'.

Where does the AID go?

Inside one of the merchant-account templates (fields 26-51). Subfield 00 of the chosen template holds the AID, followed by scheme-specific subfields. We put it in template 26 by default.

Why is currency a number?

EMVCo uses ISO 4217 numeric currency codes — 840 = USD, 978 = EUR, 392 = JPY, 156 = CNY, 986 = BRL, 764 = THB, 356 = INR, 702 = SGD, 458 = MYR, 360 = IDR, 608 = PHP, 704 = VND.

What's MCC?

Merchant Category Code, ISO 18245 — a 4-digit number identifying the merchant's industry. Common codes: 5411 = grocery, 5812 = restaurants, 5814 = fast food, 5912 = pharmacy, 5942 = bookstore, 7372 = software. Use 0000 for 'unspecified'.

What is the CRC at the end for?

EMVCo requires a 4-character CRC-16/CCITT-FALSE checksum at field 6304 to detect corruption. We compute it client-side over the entire payload + the literal '6304' tag.

Can I add a fixed amount?

Yes — set it in the amount field. Field 54 will be added and field 01 (point of initiation) flips from 11 (static, unlimited use) to 12 (dynamic, single use).

Will this work with a card-network QR like UnionPay QuickPass?

If you have the right AID, MCC, currency, and merchant routing data — yes. The TLV/CRC engine is correct. National schemes layer their own validation rules on top, so always test in the target environment before printing.