Base64 Encoder / Decoder
Convert text and files to and from Base64 encoding with URL-safe support
Base64 Encoder / Decoder
Convert text and files to and from Base64 encoding with support for URL-safe variants and custom padding options.
Overview
Base64 is a binary-to-text encoding scheme that represents binary data in an ASCII string format. It's commonly used to encode binary data for transmission over media that only support text content, such as email or URLs.
Features
π Bidirectional Conversion
- Encode: Convert plain text or files to Base64
- Decode: Convert Base64 back to original text or file content
- Auto-detection of Base64 input for smart mode switching
π‘οΈ URL-Safe Encoding
- Replace
+with-and/with_ - Perfect for tokens, URLs, and query parameters
- Optional padding removal for shorter strings
π File Support
- Load any file and convert to Base64
- Download encoded/decoded results
- Maintains file information during conversion
β‘ Quick Actions
- Copy to clipboard with one click
- Download results as text files
- Character count tracking
- Clear all with one button
How to Use
Encoding Text to Base64
- Enter your text in the Input textarea
- Ensure Encode mode is selected (default)
- Click Run to convert
- The Base64 output appears in the Output textarea
- Click Copy or Download to save the result
Example:
Input: Hello, World!
Output: SGVsbG8sIFdvcmxkIQ==
Decoding Base64 to Text
- Paste Base64 string in the Input textarea
- Select Decode mode (or let auto-detect switch for you)
- Click Run to convert
- The decoded text appears in the Output textarea
Example:
Input: SGVsbG8sIFdvcmxkIQ==
Output: Hello, World!
URL-Safe Encoding
Enable URL-Safe mode when encoding data for:
- URL query parameters
- JWT tokens
- File names
- API keys
- Cookies
Standard Base64:
Hello, World! β SGVsbG8sIFdvcmxkIQ==
Contains: + / =
URL-Safe Base64:
Hello, World! β SGVsbG8sIFdvcmxkIQ
Contains: - _ (no padding)
Loading Files
- Click Load File button
- Select any file from your computer
- File content is automatically encoded to Base64
- Mode switches to Decode to show original content
Supported Files:
- Text files (.txt, .csv, .json, etc.)
- Images (.jpg, .png, .gif, etc.)
- Documents (.pdf, .docx, etc.)
- Any binary file
Options Explained
URL-Safe Mode
When to use:
- Encoding data for URLs
- Creating tokens that will be part of a URL
- File names that need to be web-safe
- API authentication headers
What it does:
- Replaces
+with-(hyphen) - Replaces
/with_(underscore) - These characters are URL-safe and don't need encoding
Strip Padding
When to use:
- JWT tokens (they don't use padding)
- Shorter string lengths
- Systems that don't require padding
What it does:
- Removes trailing
=characters - Reduces string length
- Padding is automatically restored on decode
Important: Padding is required for standard Base64 decoding. This tool automatically restores padding when needed.
Common Use Cases
1. Embedding Images in HTML/CSS
<img src="..." />
- Encode image files to Base64
- Embed directly in HTML or CSS
- Reduces HTTP requests
2. JWT Tokens
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIn0.dozjgNryP4J3jVmNHl0w5N_XgL0n3I9PlFUP0THsR8U
- Use URL-safe encoding
- Strip padding
- Decode to read token contents
3. API Authentication
- Encode credentials for Basic Auth
- Format:
username:passwordβ Base64 - Used in Authorization headers
4. Data URLs
- Embed fonts, icons, or small files
- Reduce HTTP requests
- Improve page load times
5. Email Attachments
- MIME encoding for email attachments
- Ensures binary data survives text-only transmission
- Standard Base64 encoding
6. Storing Binary Data
- Store binary data in text-based databases
- JSON payloads with binary content
- Configuration files
Technical Details
Character Set
Base64 uses 64 characters:
- A-Z: 26 uppercase letters
- a-z: 26 lowercase letters
- 0-9: 10 digits
- + /: 2 symbols (standard)
- - _: 2 symbols (URL-safe)
- =: Padding character
Encoding Process
- Convert text to UTF-8 bytes using
TextEncoder - Group bytes into 6-bit chunks
- Map each chunk to Base64 character
- Add padding (
=) if needed to make length multiple of 4
Decoding Process
- Remove padding if present
- Convert Base64 characters to 6-bit chunks
- Combine chunks into 8-bit bytes
- Convert bytes to UTF-8 text using
TextDecoder
Size Increase
Base64 encoding increases data size by approximately 33%:
- 3 bytes (24 bits) β 4 Base64 characters (24 bits)
- 100 KB file β ~133 KB Base64 string
Unicode Support
This tool uses TextEncoder and TextDecoder for full Unicode support:
- β Emoji: π π β€οΈ
- β Special characters: Γ±, ΓΌ, Γ©
- β Asian languages: δ½ ε₯½, γγγ«γ‘γ―, μλ νμΈμ
- β Mathematical symbols: β, β«, β
Browser Compatibility
Works in all modern browsers:
- β Chrome / Edge (Chromium)
- β Firefox
- β Safari
- β Opera
- β Mobile browsers
Uses standard web APIs:
btoa()/atob()for Base64 conversionTextEncoder/TextDecoderfor UnicodeFileReaderfor file handling
Troubleshooting
"Conversion failed" Error
Problem: Invalid Base64 string
Solution:
- Check for extra whitespace or newlines
- Verify the string uses Base64 characters only
- Ensure padding is correct (or enable URL-safe mode)
Garbled Output
Problem: Wrong encoding/decoding mode
Solution:
- Switch between Encode and Decode modes
- Use URL-safe mode if input has
-or_characters - Check if padding needs to be restored
File Loading Issues
Problem: File won't load
Solution:
- Try smaller files (browser memory limits)
- Check file permissions
- Ensure file is not corrupted
Character Count Mismatch
Problem: Output size unexpected
Solution:
- Base64 is 33% larger than original
- Padding adds up to 2 characters
- URL-safe without padding is slightly shorter
Privacy & Security
β Completely Private
- All conversions happen in your browser
- No data is sent to any server
- Your files never leave your device
β No Storage
- Nothing is saved or logged
- Clear data by closing the page
- Refresh to reset everything
β οΈ Security Notes
- Base64 is encoding, not encryption
- Anyone can decode Base64 strings
- Don't use for sensitive data without encryption
- Not suitable for password storage
Best Practices
β Do's
- Use URL-safe for tokens and URLs
- Remove padding for JWT tokens
- Verify encoded data before transmission
- Test decode before using in production
- Use for appropriate data sizes (< 1 MB recommended)
β Don'ts
- Don't use as encryption (it's reversible)
- Don't encode very large files (browser limits)
- Don't store passwords in Base64
- Don't mix standard and URL-safe without converting
- Don't forget to restore padding when needed
Keyboard Shortcuts
- Ctrl/Cmd + Enter: Run conversion
- Ctrl/Cmd + K: Clear all
- Ctrl/Cmd + C: Copy output (when focused)
Examples
Example 1: Simple Text
Input: The quick brown fox
Mode: Encode
Output: VGhlIHF1aWNrIGJyb3duIGZveA==
Example 2: URL-Safe Token
Input: user@example.com:secret123
Mode: Encode (URL-safe + Strip padding)
Output: dXNlckBleGFtcGxlLmNvbTpzZWNyZXQxMjM
Example 3: Emoji Support
Input: Hello π World π
Mode: Encode
Output: SGVsbG8g8J+RiyBXb3JsZCDwn4yN
Example 4: JSON Data
Input: {"name":"John","age":30}
Mode: Encode
Output: eyJuYW1lIjoiSm9obiIsImFnZSI6MzB9
Example 5: Multiline Text
Input: Line 1
Line 2
Line 3
Mode: Encode
Output: TGluZSAxCkxpbmUgMgpMaW5lIDM=
Frequently Asked Questions
What is Base64 used for?
Base64 is used to encode binary data into text format for transmission over text-based protocols like HTTP, email, and JSON.
Is Base64 encryption?
No! Base64 is encoding, not encryption. Anyone can decode it. Never use it for security purposes.
Why does the output have = at the end?
The = characters are padding to make the output length a multiple of 4. You can remove them with the "Strip Padding" option.
Can I encode images?
Yes! Use the "Load File" button to select an image. The Base64 output can be used in data URIs.
What's the difference between standard and URL-safe?
URL-safe replaces + with - and / with _ because these don't need URL encoding.
Why is the output larger than the input?
Base64 encoding increases size by about 33% due to the encoding scheme.
Can I decode Base64 from other sources?
Yes! Just paste any valid Base64 string and click Decode.
Is there a size limit?
Browser memory limits apply (typically several hundred MB), but we recommend keeping files under 10 MB for best performance.
Related Tools
- URL Encoder/Decoder - For URL-safe string encoding
- JSON Formatter - Format and validate JSON data
- Text Diff Checker - Compare encoded/decoded versions
- Image Editor - Edit images before encoding
Technical Support
Common Patterns
Basic Auth Header:
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=
Data URI:
data:[MIME-type];base64,[Base64-encoded-data]
JWT Structure:
[header].[payload].[signature]
All three parts are Base64 URL-safe encoded
Credits
This tool uses standard browser APIs for Base64 conversion with enhanced Unicode support via TextEncoder/TextDecoder for proper handling of international characters.