--- title: データ URL slug: Web/HTTP/Basics_of_HTTP/Data_URIs tags: - Base64 - Guide - HTTP - Intermediate - URL translation_of: Web/HTTP/Basics_of_HTTP/Data_URIs ---
データ URL は data:
スキームが先頭についた URL で、小さなファイルをインラインで文書に埋め込むことができます。以前、 WHATWG で取り下げられるまでは "data URIs" と呼ばれていました。
注: 最近のブラウザーでは、データ URL はナビゲーションを担当する設定オブジェクトの起源を継承するのではなく、一意の不透明な起点として扱われます。
データ URL は接頭辞 (data:
)、データの種類を示す MIME タイプ、テキストではないデータである場合のオプションである base64
トークン、データ自体の 4 つの部品で構成されます。
data:[<mediatype>][;base64],<data>
mediatype
は MIME タイプで, 例えば 'image/jpeg'
で JPEG 画像を表します。省略時の既定値は text/plain;charset=US-ASCII
です。
データが文字ならば、そのまま埋め込めます (埋め込む文書タイプに応じて、適切な実体参照やエスケープを行なってください)。それ以外では base64
を指定し、 base64 エンコードしたバイナリデータを埋め込みます。 MIME タイプについての詳しい情報はこちらやこちらにあります。
例:
data:,Hello%2C%20World!
data:text/plain;base64,SGVsbG8sIFdvcmxkIQ==
data:text/html,%3Ch1%3EHello%2C%20World!%3C%2Fh1%3E
<h1>Hello, World!</h1>
という HTML 文書data:text/html,<script>alert('hi');</script>
Base64 はバイナリからテキストへのエンコード方法の集まりで、バイナリデータを64進数表現に変換することで ASCII 文字列形式にするものです。 ASCII 文字のみから成るため、 Base64 の文字列は一般に URL でも安全ですので、データ URL のデータのエンコードに利用することができます。
Web API には、 Base64 をエンコードまたはデコードするためのネイティブメソッド、 Base64 encoding and decoding があります。
Linux や Mac OS X システムでのファイルまたは文字列の Base64 エンコードは、コマンドラインの base64
(または、他にも uuencode
ユーティリティの -m
オプションつき) を使用して実現できます。
echo -n hello|base64 # コンソールへの出力: aGVsbG8= echo -n hello>a.txt base64 a.txt # コンソールへの出力: aGVsbG8= base64 a.txt>b.txt # b.txt ファイルへの出力: aGVsbG8=
Windows では、 Convert.ToBase64String を PowerShell で使用することで Base64 エンコードを行うことができます。
[convert]::ToBase64String([Text.Encoding]::UTF8.GetBytes("hello")) # outputs to console: aGVsbG8=
他にも、 GNU/Linux シェル (WSL など) が base64
ユーティリティを提供しています。
bash$ echo -n hello | base64 # outputs to console: aGVsbG8=
この章では data
の URL を作ったり使ったりするときに、よく起こる問題について述べます。
data:text/html,lots of text...<p><a name%3D"bottom">bottom</a>?arg=val
これは次の内容の HTML リソースを表します。
lots of text...<p><a name="bottom">bottom</a>?arg=val
data
URL の書式は非常に単純ですが、"データ" 部分の前にカンマを置くのを忘れがちです。忘れるとデータが正しく base64 形式にエンコードされません。data
はファイル内でファイルを提供しますが、外側の文書に比べて幅がとても広くなる可能性があります。 URL としては、 data
はホワイトスペース (改行、タブ、空白) で体裁を整えることができるはずですが、 base64 エンコードをすると起こる問題 があります。data
URL に対応していますが、ブラウザーは特定の最大長のデータに対応する必要はありません。たとえば、 Opera 11 ブラウザーでは URL が65535文字に制限されており、 data
URL は65529文字に制限されています (65529文字は、 MIME タイプを指定せずにプレーンの data:
を使用した場合、ソースではなくエンコードされたデータの長さです)。'base64'
の定義内の打ち間違いは無視され、何もエラーは出ません。データ URL のデータ部分は不透明 (opaque) なので、データ URL と一緒にクエリ文字列 (<url>?parameter-data
という構文で表されるページ固有のパラメータ) を使うと、データ URL が表現するデータに単にクエリ文字列が含まれたものになります。
data://
URL へのトップレベルのナビゲーションがブロックされており、他のブラウザがすぐに対応することを期待しています。詳細については、Firefox 58 におけるデータ URL へのトップレベルナビゲーションのブロックを参照してください。仕様書 | 題名 |
---|---|
{{RFC("2397")}} | The "data" URL scheme |
{{compat("http.data-url")}}
url()