Data URLs
Data URLs
Data URLs, URLs prefixed with the data:
scheme, allow content creators to embed small files inline in documents. They were formerly known as "data URIs" until that name was retired by the WHATWG.
Note: Data URLs are treated as unique opaque origins by modern browsers, rather than inheriting the origin of the settings object responsible for the navigation.
Syntax
Data URLs are composed of four parts: a prefix (data:
), a MIME type indicating the type of data, an optional base64
token if non-textual, and the data itself:
data:[<mediatype>][;base64],<data>
The mediatype
is a MIME type string, such as 'image/jpeg'
for a JPEG image file. If omitted, defaults to text/plain;charset=US-ASCII
If the data contains characters defined in RFC 3986 as reserved characters, or contains space characters, newline characters, or other non-printing characters, those characters must be percent-encoded (aka "URL-encoded").
If the data is textual, you can embed the text (using the appropriate entities or escapes based on the enclosing document's type). Otherwise, you can specify base64
to embed base64-encoded binary data. You can find more info on MIME types here and here.
A few examples:
-
data:,Hello%2C%20World%21
-
The text/plain data Hello, World!
. Note how the comma is percent-encoded as %2C
, and the space character as %20
.
-
data:text/plain;base64,SGVsbG8sIFdvcmxkIQ==
-
base64-encoded version of the above
-
data:text/html,%3Ch1%3EHello%2C%20World%21%3C%2Fh1%3E
-
An HTML document with <h1>Hello, World!</h1>
-
data:text/html,%3Cscript%3Ealert%28%27hi%27%29%3B%3C%2Fscript%3E
-
An HTML document with <script>alert('hi');</script>
that executes a JavaScript alert. Note that the closing script tag is required.
Base64 is a group of binary-to-text encoding schemes that represent binary data in an ASCII string format by translating it into a radix-64 representation. By consisting only of ASCII characters, base64 strings are generally url-safe, and that's why they can be used to encode data in Data URLs.
Encoding on a Unix system
Base64 encoding of a file or string on Linux and macOS systems can be achieved using the command-line base64
(or, as an alternative, the uuencode
utility with -m
argument).
echo -n hello|base64
echo -n hello>a.txt
base64 a.txt
base64 a.txt>b.txt
Encoding on Microsoft Windows
On Windows, Convert.ToBase64String from PowerShell can be used to perform the Base64 encoding:
[convert]::ToBase64String([Text.Encoding]::UTF8.GetBytes("hello"))
# outputs to console: aGVsbG8=
Alternatively, a GNU/Linux shell (such as WSL) provides the utility base64
:
bash$ echo -n hello | base64
Common problems
This section describes problems that commonly occur when creating and using data
URLs.
data:text/html,lots of text…<p><a name%3D"bottom">bottom</a>?arg=val</p>
This represents an HTML resource whose contents are:
lots of text…
<p><a name="bottom">bottom</a>?arg=val</p>
-
Syntax
-
The format for data
URLs is very simple, but it's easy to forget to put a comma before the "data" segment, or to incorrectly encode the data into base64 format.
-
Formatting in HTML
-
A data
URL provides a file within a file, which can potentially be very wide relative to the width of the enclosing document. As a URL, the data
should be formattable with whitespace (linefeed, tab, or spaces), but there are practical issues that arise when using base64 encoding.
-
Length limitations
-
Browsers are not required to support any particular maximum length of data. For example, the Opera 11 browser limited URLs to 65535 characters long which limits data
URLs to 65529 characters (65529 characters being the length of the encoded data, not the source, if you use the plain data:
, without specifying a MIME type). Firefox version 97 and newer supports data
URLs of up to 32MB (before 97 the limit was close to 256MB). Chromium objects to URLs over 512MB, and Webkit (Safari) to URLs over 2048MB.
-
Lack of error handling
-
Invalid parameters in media, or typos when specifying 'base64'
, are ignored, but no error is provided.
-
No support for query strings, etc.
-
The data portion of a data URL is opaque, so an attempt to use a query string (page-specific parameters, with the syntax <url>?parameter-data
) with a data URL will just include the query string in the data the URL represents.
-
Security issues
-
A number of security issues (for example, phishing) have been associated with data URLs, and navigating to them in the browser's top level. To mitigate such issues, top-level navigation to data:
URLs is blocked in all modern browsers. See this blog post from the Mozilla Security Team for more details.
Specifications
Browser compatibility
|
Desktop |
Mobile |
|
Chrome |
Edge |
Firefox |
Internet Explorer |
Opera |
Safari |
WebView Android |
Chrome Android |
Firefox for Android |
Opera Android |
Safari on IOS |
Samsung Internet |
Data_URLs |
Yes
|
12
Before Edge 79, the maximum size supported is 4GB.
|
Yes
|
8
["Since Internet Explorer 9, the maximum size supported is 4GB.", "In Internet Explorer 8, the maximum size supported is 32kB."]
|
7.2
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
css_files |
Yes
|
12
|
Yes
|
8
|
7.2
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
html_files |
Yes
|
79
|
Yes
|
No
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
js_files |
Yes
|
12
|
Yes
|
9
|
7.2
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
Yes
|
top_level_navigation_blocked |
60
|
≤79
|
59
|
No
|
47
|
14
|
No
|
60
|
59
|
44
|
14
|
8.0
|