PHP: Decode Base64URL to JSON safely

TL;DR: Validate locally, fix the first real error, validate again (no upload).

Handle PHP: Decode Base64URL to JSON safely with a repeatable Base64URL workflow: normalize alphabet, fix padding, decode locally, and validate.

Base64URL quick map

RuleBase64Base64URL
Alphabet+, /-, _
PaddingOften has =Often omits =
Typical useGeneral binary transportURLs, JWT segments

Focus for this query

  • If this value came from a URL parameter, URL-decode first, then normalize Base64URL.

Safe decode workflow

  1. Remove whitespace/newlines.
  2. Normalize alphabet: -+, _/.
  3. Add padding so length % 4 == 0.
  4. Decode locally and validate output shape (JSON/text/binary).

Runtime snippet (generic)

function base64urlToBase64(input) {
  const s = String(input || '').replace(/\s+/g, '').replace(/-/g, '+').replace(/_/g, '/');
  return s + '='.repeat((4 - (s.length % 4)) % 4);
}

const b64 = base64urlToBase64(token);
const bytes = Uint8Array.from(atob(b64), (c) => c.charCodeAt(0));
const text = new TextDecoder().decode(bytes);
console.log(text);

Frequent failures

Privacy guardrail

Base64/Base64URL strings can still contain secrets. Decode locally, redact sensitive fields, and only then share snippets.

FAQ

Is anything uploaded to a server? No. All processing happens locally in your browser. Files are never uploaded.

What is the recommended workflow? Validate the input, fix the first real issue, validate again, then export/convert. This avoids compounding errors.

Privacy & Security
All processing happens locally in your browser. Files are never uploaded.