Fetch

現行標準 — 最終更新

参加方法:
GitHub whatwg/fetch新しいissueオープン中のissue
Matrixでチャット
コミット:
GitHub whatwg/fetch/commits
このコミット時点のスナップショット
@fetchstandard
テスト:
web-platform-tests fetch/進行中の作業
翻訳 (参考情報):
日本語
简体中文
한국어

概要

Fetch標準は、リクエスト、レスポンス、およびそれらを結び付ける処理であるフェッチ処理を定義します。

目標

この標準の目標は、ウェブプラットフォーム全体でフェッチ処理を統一し、関連する全ての事項について一貫した取り扱いを提供することです。具体的には以下を含みます。

そのため、この標準はThe Web Origin Conceptで最初に定義されたHTTP `Origin`ヘッダーのセマンティクスも置き換えます。[ORIGIN]

1. 序文

大まかに言えば、リソースのフェッチは非常に単純な操作です。リクエストが入力され、レスポンスが出力されます。しかしその詳細は複雑であり、かつては十分に文書化されていなかったり、APIごとに異なっていました。

多くのAPIがリソースをフェッチする機能を提供しています。例えばHTMLのimgscript要素、CSSのcursorlist-style-image、JavaScript APIであるnavigator.sendBeacon()self.importScripts()などです。Fetch標準は、これらの機能について統一的なアーキテクチャを提供し、リダイレクトやCORSプロトコルなどフェッチに関する様々な側面で一貫性を持たせます。

Fetch標準はまた、ほとんどのネットワーク機能を比較的低レベルの抽象化で公開するfetch() JavaScript APIも定義します。

2. インフラストラクチャー

本仕様はInfra標準に依存します。[INFRA]

本仕様は、ABNFEncodingHTMLHTTPMIME SniffingStreamsURLWeb IDLWebSockets、およびWebTransportの用語を使用します。 [ABNF] [ENCODING] [HTML] [HTTP] [MIMESNIFF] [STREAMS] [URL] [WEBIDL] [WEBSOCKETS] [WEBTRANSPORT]

ABNF とは、HTTPによって拡張されたABNF(特に#の追加)およびRFC 7405を意味します。[RFC7405]


認証情報 とは、HTTPクッキー、TLSクライアント証明書、および認証エントリ(HTTP認証用)を指します。[COOKIES] [TLS] [HTTP]


fetch params は、構造体であり、 fetchアルゴリズムで帳簿管理の詳細として使われます。次の項目を持ちます:

request
request
リクエストボディチャンク長の処理 (デフォルト:null)
process request end-of-body(初期値 null)
process early hints response(初期値 null)
process response(初期値 null)
process response end-of-body(初期値 null)
process response consume body(初期値 null)
nullまたはアルゴリズム。
task destination(初期値 null)
null、グローバルオブジェクト、または並列キュー
cross-origin isolated capability(初期値 false)
真偽値。
controller(初期値 新しいfetch controller
fetch controller
timing info
fetch timing info
preloaded response candidate(初期値 null)
null、"pending"、またはresponse

fetch controllerは、 構造体であり、 fetchの呼び出し元が開始後に特定の操作を行うことを可能にします。次の項目を持ちます:

state(初期値 "ongoing")
"ongoing"、"terminated"、または"aborted"。
full timing info(初期値 null)
nullまたはfetch timing info
report timing steps(初期値 null)
nullまたはグローバルオブジェクトを受け取るアルゴリズム。
serialized abort reason(初期値 null)
nullまたはRecordStructuredSerializeの結果)。
next manual redirect steps(初期値 null)
nullまたは何も受け取らないアルゴリズム。

fetch controller controllerに対して、global object globalを与えて、report timingするには:

  1. Assert: controllerreport timing stepsがnullでないことを確認する。

  2. controllerreport timing stepsglobalで呼び出す。

fetch controller controllerに対してprocess the next manual redirectするには:

  1. Assert: controllernext manual redirect stepsが nullでないことを確認する。

  2. controllernext manual redirect stepsを呼び出す。

fetch controller controllerに対してextract full timing infoするには:

  1. Assert: controllerfull timing info がnullでないことを確認する。

  2. controllerfull timing infoを返す。

fetch controller controllerに対して、オプションのerrorabortするには:

  1. controllerstateを"aborted"に設定する。

  2. fallbackErrorを"AbortError" DOMExceptionとする。

  3. errorが与えられなければ、fallbackErrorを設定する。

  4. serializedErrorStructuredSerialize(error)とする。 例外が発生したら、それをキャッチしてserializedErrorStructuredSerialize(fallbackError)とする。

  5. controllerserialized abort reasonserializedErrorを設定する。

nullまたはRecord abortReasonrealm realmを与えて、serialized abort reasonをデシリアライズするには:

  1. fallbackErrorを"AbortError" DOMExceptionとする。

  2. deserializedErrorfallbackErrorとする。

  3. abortReasonがnullでなければ、 deserializedErrorStructuredDeserialize(abortReason, realm)を設定する。 例外が発生したりundefinedを返したら、deserializedErrorfallbackErrorに設定する。

  4. deserializedErrorを返す。

fetch controller controllerに対してterminateするには、controllerstateを "terminated"に設定する。

fetch params fetchParamsは、そのcontrollerstateが "aborted"であれば、abortedである。

fetch params fetchParamsは、そのcontrollerstateが "aborted"または"terminated"であれば、canceledである。

fetch timing infoは、 構造体であり、 Resource TimingNavigation Timingで必要なタイミング情報を保持します。次の項目を持ちます: [RESOURCE-TIMING] [NAVIGATION-TIMING]

start time(初期値 0)
redirect start time(初期値 0)
redirect end time(初期値 0)
post-redirect start time(初期値 0)
final service worker start time (初期値 0)
final network-request start time (初期値 0)
first interim network-response start time(初期値 0)
final network-response start time (初期値 0)
end time(初期値 0)
DOMHighResTimeStamp
final connection timing info(初期値 null)
nullまたはconnection timing info
service worker timing info(デフォルトは null)
null または service worker timing info です。
server-timing headers(初期値 « »)
文字列のリスト
render-blocking(初期値 false)
真偽値。

response body info は、構造体であり、 Resource TimingNavigation Timingで必要な情報を保持します。次の項目を持ちます: [RESOURCE-TIMING] [NAVIGATION-TIMING]

encoded size (初期値 0)
decoded size (初期値 0)
数値。
content type(初期値 空文字列)
ASCII文字列
content encoding(初期値 空文字列)
ASCII文字列

fetch timing info timingInfoを与えてopaque timing infoを作成するには、 timingInfostart timeおよび post-redirect start timetimingInfostart timeとなる 新しいfetch timing infoを返す。

アルゴリズムalgorithmグローバルオブジェクトまたは並列キュー taskDestinationを与えてfetchタスクをキューするには、次の手順を実行する:

  1. taskDestination並列キューであれば、 enqueue algorithmtaskDestinationへ。

  2. それ以外の場合、グローバルタスクをキューする。networking task sourcetaskDestinationおよびalgorithmとともに。

環境設定オブジェクト environment オフラインかどうかを確認するには:


整数を直列化するには、最も短い10進数の文字列として表現する。

これは今後、Infraでより詳細なアルゴリズムに置き換えられます。詳しくは infra/201を参照してください。

2.1. URL

ローカルスキームは 「about」、「blob」、または 「data」です。

URLは、そのスキームローカルスキームであれば、 ローカルです。

この定義はReferrer Policyでも使用されています。[REFERRER]

HTTP(S)スキームは 「http」または 「https」です。

fetchスキームは 「about」、「blob」、 「data」、「file」、またはHTTP(S)スキームです。

HTTP(S)スキームおよびfetchスキームHTMLでも使われます。 [HTML]

2.2. HTTP

フェッチはHTTPだけでなくより広い概念を含みますが、多くの概念をHTTPから借用し、それらを他の手段(例:data URL)で取得したリソースにも適用します。

HTTPタブまたはスペースは U+0009 TAB または U+0020 SPACE です。

HTTP空白はU+000A LF、U+000D CR、またはHTTPタブまたはスペースです。

HTTP空白は、HTTPヘッダー以外の文脈(例:MIMEタイプ)で再利用される特定の構文だけに役立ちます。HTTPヘッダー値ではHTTPタブまたはスペースの使用が推奨され、それ以外の文脈ではASCII空白の方が好まれます。ASCII空白とは異なり、U+000C FFは除外されます。

HTTP改行バイトは 0x0A (LF) または 0x0D (CR) です。

HTTPタブまたはスペースバイトは 0x09 (HT) または 0x20 (SP) です。

HTTP空白バイトは、HTTP改行バイトまたは HTTPタブまたはスペースバイトです。

文字列 input位置変数 position、および省略可能な真偽値extract-value(初期値はfalse)を与えて HTTP引用文字列を収集するには、次の手順を実行する:

  1. positionStartpositionとする。

  2. valueを空文字列とする。

  3. Assertinputposition符号位置が U+0022 (") であること。

  4. positionを1進める。

  5. 無限ループ:

    1. positionからU+0022 (") または U+005C (\) でない符号位置の列を収集し、その結果をvalueに追加する。

    2. positioninputの末尾を過ぎていれば break

    3. quoteOrBackslashinputposition符号位置とする。

    4. positionを1進める。

    5. quoteOrBackslashがU+005C (\) なら:

      1. positioninputの末尾を過ぎていれば、U+005C (\) をvalueに追加しbreak

      2. inputposition符号位置valueに追加する。

      3. positionを1進める。

    6. それ以外の場合:

      1. AssertquoteOrBackslashはU+0022 (") であること。

      2. break

  6. extract-valueがtrueなら、valueを返す。

  7. inputpositionStartからpositionまでの符号位置を返す。

入力 出力 extract-valueがtrueの場合の出力 最終的な位置変数の値
""\" ""\" "\" 2
""Hello" World" ""Hello"" "Hello" 7
""Hello \\ World\""" ""Hello \\ World\""" "Hello \ World"" 18

これらの例では位置変数は常に0から開始します。

2.2.1. メソッド

メソッドとは、バイト列であり、 methodトークン生成規則に一致するものです。

CORSセーフリストメソッドとは、 メソッドのうち、 `GET`、`HEAD`、`POST` のいずれかです。

禁止メソッドとは、 メソッドのうち、 `CONNECT`、`TRACE`、`TRACK` と バイト大小区別なしで一致するものです。 [HTTPVERBSEC1][HTTPVERBSEC2][HTTPVERBSEC3]

メソッド正規化するには、それが `DELETE`、`GET`、`HEAD`、`OPTIONS`、`POST`、`PUT` のいずれかとバイト大小区別なしで一致する場合、 バイト大文字化すること。

正規化は後方互換性およびAPI間の一貫性のために行われます。実際にはメソッドは「大文字小文字を区別」します。

`patch`を使うとほとんどの場合 `405 Method Not Allowed` になります。`PATCH` のほうが成功しやすいです。

メソッドには制限はありません。`CHICKEN`も完全に許容されます(`CHECKIN`の綴り間違いではありません)。正規化されるもの以外は大文字小文字の制限もありません。`Egg`や`eGg`でも問題ありませんが、一貫性のため大文字を推奨します。

2.2.2. ヘッダー

HTTPでは一般的に、ヘッダーを「フィールド」または「ヘッダーフィールド」と呼びます。ウェブプラットフォームでは、より口語的な「ヘッダー」という用語が使われます。[HTTP]

ヘッダーリストとは、ゼロ個以上のリストであり、 ヘッダーから成ります。初期値は « » です。

ヘッダーリストは本質的に特殊なマルチマップ、すなわち重複するキーを持つ可能性のある順序付きキー・バリューのリストです。`Set-Cookie`以外のヘッダーは常にクライアントサイドJavaScriptに公開される際に結合されるため、実装はより効率的な表現を選択しても問題ありませんが、`Set-Cookie`ヘッダー用の関連するデータ構造はサポートする必要があります。

ヘッダー名nameと文字列typeヘッダーリスト listから与えて、 構造化フィールド値を取得 するには、次の手順を実行します。返り値はnullまたは構造化フィールド値です。

  1. Assert: typeは"dictionary"、"list"、"item"のいずれかであること。

  2. valuelistからname取得した結果を格納する。

  3. valueがnullなら、nullを返す。

  4. resultinput_stringvalueheader_typetypeとしてstructured fieldsをパースした結果を格納する。

  5. パースに失敗した場合、nullを返す。

  6. resultを返す。

構造化フィールド値の取得は、ヘッダーが存在しない場合と、そののパースが 構造化フィールド値として失敗した場合を区別しません。これによりウェブプラットフォーム全体で一貫した処理が保証されます。

タプルヘッダー名 name構造化フィールド値 structuredValue)と ヘッダーリスト listを与えて 構造化フィールド値を設定するには:

  1. serializedValuestructured fieldsのシリアライズアルゴリズムをstructuredValueに対して実行した結果を格納する。

  2. 設定name, serializedValue)を listに行う。

構造化フィールド値はHTTPが(将来的に)興味深く効率的な方法でシリアライズできるオブジェクトとして定義されています。現時点では、Fetchはヘッダー値バイト列としてのみサポートしているため、これらのオブジェクトはシリアライズを通じてのみ ヘッダーリストに設定でき、 パースによってのみヘッダーリストから取得できます。将来的にはこれらがエンドツーエンドでオブジェクトとして保持される可能性があります。[RFC9651]


ヘッダーリスト listヘッダー名 name含むのは、 list含むとき、ヘッダーであって、 その名前バイト大小区別なしnameと一致する場合です。

ヘッダー名 nameヘッダーリスト listから 取得するには、次の手順を実行する。返り値はnullまたはヘッダー値

  1. list含まない場合、nullを返す。

  2. list内の、ヘッダー名前バイト大小区別なしnameと一致するものすべての を、0x2C 0x20で区切って順番通りに返す。

ヘッダー名 nameヘッダーリスト listから 取得・デコード・分割するには、次の手順を実行する。返り値はnullまたは文字列のリスト

  1. valueに、listからname取得した結果を格納する。

  2. valueがnullなら、nullを返す。

  3. value取得・デコード・分割した結果を返す。

取得・デコード・分割が、`A`をname引数として実際にどのように動作するかを示します:

ヘッダー(ネットワーク上) 出力
A: nosniff,
« "nosniff", "" »
A: nosniff
B: sniff
A:
A:
B: sniff
« "" »
B: sniff
null
A: text/html;", x/x
« "text/html;", x/x" »
A: text/html;"
A: x/x
A: x/x;test="hi",y/y
« "x/x;test="hi"", "y/y" »
A: x/x;test="hi"
C: **bingo**
A: y/y
A: x / x,,,1
« "x / x", "", "", "1" »
A: x / x
A: ,
A: 1
A: "1,2", 3
« ""1,2"", "3" »
A: "1,2"
D: 4
A: 3

ヘッダー値 value取得・デコード・分割するには、次の手順を実行します。返り値は文字列のリストです。

  1. inputvalueisomorphic decodeした結果を格納する。

  2. positioninput位置変数として、先頭位置に設定する。

  3. values文字列のリストとして初期化する(初期値 « »)。

  4. temporaryValueを空文字列とする。

  5. 無限ループ:

    1. positionからU+0022 (") または U+002C (,) でない符号位置の列を収集し、その結果をtemporaryValueに追加する。

      この結果は空文字列でもよい。

    2. positioninputの末尾を過ぎておらず、かつinputposition符号位置がU+0022 (")なら:

      1. inputpositionHTTP引用文字列を収集し、その結果をtemporaryValueに追加する。

      2. positionがまだ末尾を過ぎていなければcontinue
    3. temporaryValueの先頭および末尾からすべてのHTTPタブまたはスペースを除去する。

    4. 追加 temporaryValuevaluesに。

    5. temporaryValueを空文字列に戻す。

    6. positioninputの末尾を過ぎていれば、valuesを返す。

    7. Assertinputposition符号位置はU+002C (,)であること。

    8. positionを1だけ進める。

祝福された呼び出し箇所以外では、このアルゴリズムは直接呼び出してはいけません。代わりに取得・デコード・分割を使ってください。

ヘッダー (name, value) をヘッダーリスト list追加するには:

  1. listname含む場合、nameを最初に該当するヘッダー名前に設定する。

    これによって、既存のヘッダー名前の大文字・小文字が再利用されます。複数一致する場合、すべてのヘッダー名前は同一になります。

  2. 追加 (name, value) をlistに。

ヘッダー名 nameヘッダーリスト listから削除するには、 削除 ヘッダーすべて(名前バイト大小区別なしnameと一致するもの)をlistから取り除く。

ヘッダー (name, value) をヘッダーリスト list設定するには:

  1. listname含む場合、最初の該当ヘッダーvalueに設定し、他の該当ヘッダーは削除する。

  2. それ以外の場合、追加 (name, value) をlistに。

ヘッダー (name, value) をヘッダーリスト list結合するには:

  1. listname含む場合、最初の該当ヘッダーの後ろに0x2C 0x20を挟んでvalueを追加する。

  2. それ以外の場合、追加 (name, value) をlistに。

結合XMLHttpRequest および WebSocketプロトコルハンドシェイクで使われます。

名前のリスト headerNamesを与えてソート済み小文字集合へ変換するには、次の手順を実行する。返り値は順序付き集合ヘッダー名)。

  1. headerNamesSetを新しい順序付き集合とする。

  2. headerNamesnameについて、追加として、バイト小文字化したnameheaderNamesSetに加える。

  3. 昇順ソートheaderNamesSetに対してバイト小なりで行い、その結果を返す。

ヘッダーリスト listソートおよび結合するには、次の手順を実行する。返り値はヘッダーリスト

  1. headersヘッダーリストとして初期化する。

  2. namesに、list内の全名前ソート済み小文字集合へ変換した結果を格納する。

  3. namesnameについて:

    1. nameが`set-cookie`なら:

      1. valueslist内でnameバイト大小区別なしで一致するヘッダーすべてのを順番通り格納するリストとする。

      2. valuesvalueについて:

        1. 追加 (name, value) をheadersに。

    2. それ以外の場合:

      1. valuelistからname取得した結果を格納する。

      2. Assertvalueはnullでないこと。

      3. 追加 (name, value) をheadersに。

  4. headersを返す。


ヘッダーは、タプルであり、 名前ヘッダー名)と ヘッダー値)から構成されます。

ヘッダー名は、バイト列であり、 field-nameトークン生成規則に一致するものです。

ヘッダー値は、バイト列であり、次の条件を満たすものです。

ヘッダー値の定義は、field-valueトークン生成規則に基づいていません。これは既存のコンテンツとの非互換性があるためです。

バイト列 potentialValue正規化するには、potentialValueから先頭および末尾のHTTP空白バイトを除去する。


ヘッダーname, value)がCORSセーフリストリクエストヘッダーかどうかを判定するには、次の手順を実行する:

  1. value長さが128より大きい場合、falseを返す。

  2. バイト小文字化したnameで次の分岐を行う:

    `accept`

    valueCORS-unsafeリクエストヘッダーバイトが含まれていれば、falseを返す。

    `accept-language`
    `content-language`

    valueに、0x30 (0)~0x39 (9)、0x41 (A)~0x5A (Z)、0x61 (a)~0x7A (z)、0x20 (SP)、0x2A (*)、0x2C (,)、0x2D (-)、0x2E (.)、0x3B (;)、0x3D (=) 以外のバイトが含まれていれば、falseを返す。

    `content-type`
    1. valueCORS-unsafeリクエストヘッダーバイトが含まれていれば、falseを返す。

    2. mimeTypeMIMEタイプのパースisomorphic decodeしたvalueに対して行った結果を格納する。

    3. mimeTypeがfailureならfalseを返す。

    4. mimeTypeessenceが "application/x-www-form-urlencoded", "multipart/form-data", "text/plain" 以外ならfalseを返す。

    ここではMIMEタイプの抽出アルゴリズムは使いません。これは寛容すぎるためで、サーバー側がそのまま実装することを想定していません。

    MIMEタイプの抽出を使った場合、次のリクエストはCORSプリフライトにならず、サーバーの単純なパーサーがリクエストボディをJSONとして扱うかもしれません:

    fetch("https://victim.example/naïve-endpoint", {
      method: "POST",
      headers: [
        ["Content-Type", "application/json"],
        ["Content-Type", "text/plain"]
      ],
      credentials: "include",
      body: JSON.stringify(exerciseForTheReader)
    });
    
    `range`
    1. rangeValue単一レンジヘッダー値のパースvalueとfalseで行った結果を格納する。

    2. rangeValueがfailureならfalseを返す。

    3. rangeValue[0]がnullならfalseを返す。

      ウェブブラウザは歴史的に `bytes=-500` のようなレンジは出さないため、このアルゴリズムはそれらをセーフリスト化しません。

    その他

    falseを返す。

  3. trueを返す。

`Content-Type`ヘッダーのセーフリストには限定的な例外があり、CORSプロトコルの例外に記載されています。

CORS-unsafeリクエストヘッダーバイトとは、バイトbyteが次のいずれかに該当する場合です:

CORS-unsafeリクエストヘッダー名は、ヘッダーリスト headersに対して次の手順で決定します:

  1. unsafeNamesを新しいリストとする。

  2. potentiallyUnsafeNamesを新しいリストとする。

  3. safelistValueSizeを0とする。

  4. headersheader について:

    1. headerCORSセーフリストリクエストヘッダーでなければ、appendheader名前unsafeNamesに加える。

    2. それ以外の場合、appendheader名前potentiallyUnsafeNamesに加え、safelistValueSizeheader長さを加算する。

  5. safelistValueSizeが1024より大きければ、 potentiallyUnsafeNamesnameについて、appendnameunsafeNamesに加える。

  6. ソート済み小文字集合へ変換したunsafeNamesを返す。

CORSノンワイルドカードリクエストヘッダー名は、ヘッダー名であり、バイト大小区別なしで`Authorization`と一致するものです。

特権no-CORSリクエストヘッダー名は、ヘッダー名であり、 バイト大小区別なしで以下のいずれかと一致するものです。

これらは特権APIによって設定できるヘッダーであり、関連するリクエストオブジェクトがコピーされた場合は保持されますが、非特権APIによってリクエストが変更された場合には削除されます。

`Range`ヘッダーは、ダウンロードメディアの取得によく使われます。

特定のリクエストにRangeヘッダーを追加するためのヘルパーも用意されています。

CORSセーフリストレスポンスヘッダー名は、リスト ヘッダー名 list を与えて、以下のいずれかにバイト大小区別なしで一致するヘッダー名です。

no-CORSセーフリストリクエストヘッダー名は、ヘッダー名であり、 バイト大小区別なしで以下のいずれかと一致するものです。

ヘッダーname, value)がno-CORSセーフリストリクエストヘッダーかどうかを判定するには、次の手順を実行します:

  1. nameno-CORSセーフリストリクエストヘッダー名でなければfalseを返す。

  2. name, value)がCORSセーフリストリクエストヘッダーかどうかを返す。

ヘッダーname, value)が禁止リクエストヘッダーかどうかは、次の手順でtrueなら該当します:

  1. nameが、次のいずれかにバイト大小区別なしで一致すればtrueを返す:

    該当すればtrueを返す。

  2. nameバイト小文字化し、`proxy-`または`sec-`で始まる場合、trueを返す。

  3. nameが、次のいずれかにバイト大小区別なしで一致すれば:

    • `X-HTTP-Method`
    • `X-HTTP-Method-Override`
    • `X-Method-Override`

    その場合:

    1. parsedValues取得・デコード・分割したvalueの結果を格納する。

    2. parsedValuesmethodについて、 そのisomorphic encode禁止メソッドであればtrueを返す。

  4. falseを返す。

これらはユーザーエージェントが完全に制御できるようにするために禁止されています。

ヘッダー名が`Sec-`で始まるものは、新しいヘッダーをAPIで開発者が制御できるfetch系API(例:XMLHttpRequest)で安全に追加できるように予約されています。[XHR]

`Set-Cookie`ヘッダーは意味的にはレスポンスヘッダーであり、リクエストには不要です。また、`Set-Cookie`ヘッダーは結合できないため、Headersオブジェクトではより複雑な処理が必要となります。ここで禁止することで、この複雑さがリクエストに漏れないようにしています。

禁止レスポンスヘッダー名は、ヘッダー名であり、バイト大小区別なしで以下のいずれかに一致するものです。

リクエストボディヘッダー名は、ヘッダー名であり、バイト大小区別なしで以下のいずれかに一致するものです。


ヘッダー headerに対してヘッダー値を抽出するには次の手順を実行します:

  1. headerを、そのheader名前に該当するABNFでパースして失敗したらfailureを返す。

  2. headerを、そのheader名前に該当するABNFでパースした結果の1つ以上の値を返す。

ヘッダー名 nameヘッダーリスト listを与えてヘッダーリスト値を抽出するには次の手順を実行します:

  1. listname含まない場合、nullを返す。

  2. nameに該当するABNFが単一のヘッダーしか許可しない場合、かつlistが複数含む場合はfailureを返す。

    異なるエラー処理が必要な場合は、先に必要なヘッダーを抽出してください。

  3. valuesを空のリストとする。

  4. listnameヘッダーを含む各headerについて:

    1. extractheaderからヘッダー値を抽出した結果を格納する。

    2. extractがfailureならfailureを返す。

    3. extract内の各を順番にvaluesへ追加する。

  5. valuesを返す。

整数rangeStart、整数rangeEnd、整数fullLengthを与えてコンテンツレンジを構築するには、次の手順を実行します:

  1. contentRangeを`bytes `とする。

  2. rangeStart直列化し、isomorphic encodeしてcontentRangeに追加する。

  3. 0x2D (-) をcontentRangeに追加する。

  4. rangeEnd直列化し、isomorphic encodeしてcontentRangeに追加する。

  5. 0x2F (/) をcontentRangeに追加する。

  6. fullLength直列化し、isomorphic encodeしてcontentRangeに追加する。

  7. contentRangeを返す。

バイト列 valueと真偽値allowWhitespaceを与えて単一レンジヘッダー値のパースを行うには、次の手順を実行します:

  1. datavalueisomorphic decodeした結果を格納する。

  2. dataが"bytes"で始まらない場合、failureを返す。

  3. positiondataの5番目の符号位置を指す位置変数として初期化する。

  4. allowWhitespaceがtrueなら、HTTPタブまたはスペースdatapositionから収集する。

  5. positiondataにおける符号位置がU+003D (=)でなければfailureを返す。

  6. positionを1進める。

  7. allowWhitespaceがtrueなら、HTTPタブまたはスペースdatapositionから収集する。

  8. rangeStartdatapositionからASCII数字の列を収集した結果を格納する。

  9. rangeStartValuerangeStartが空でなければ10進数として解釈した値を、空ならnullを格納する。

  10. allowWhitespaceがtrueなら、HTTPタブまたはスペースdatapositionから収集する。

  11. positiondataにおける符号位置がU+002D (-)でなければfailureを返す。

  12. positionを1進める。

  13. allowWhitespaceがtrueなら、HTTPタブまたはスペースdatapositionから収集する。

  14. rangeEnddatapositionからASCII数字の列を収集した結果を格納する。

  15. rangeEndValuerangeEndが空でなければ10進数として解釈した値を、空ならnullを格納する。

  16. positiondataの末尾を過ぎていなければfailureを返す。

  17. rangeEndValuerangeStartValueが両方nullならfailureを返す。

  18. rangeStartValuerangeEndValueが数値で、rangeStartValuerangeEndValueより大きければfailureを返す。

  19. (rangeStartValue, rangeEndValue)を返す。

    rangeのendまたはstartは省略可能であり、`bytes=0-`や`bytes=-500`も有効なレンジです。

単一レンジヘッダー値のパースは許可されるレンジヘッダー値の一部でしか成功しませんが、ユーザーエージェントがメディアやダウンロード再開時に使用する最も一般的な形式です。この形式のレンジヘッダー値はRangeヘッダーを追加で設定できます。


デフォルト`User-Agent`値は、`User-Agent`ヘッダーに対する実装依存ヘッダー値です。

不幸なウェブ互換性の理由から、ウェブブラウザーはこの値を `Mozilla/5.0 (` で始めること、そして他のウェブブラウザーを一般的に模倣することが強く推奨されています。

環境設定オブジェクト environment環境のデフォルト `User-Agent` 値 を取得するには、次の手順に従う:

  1. userAgentWebDriver BiDi エミュレートされた User-Agentenvironment 用)として取得する。

  2. userAgent が非 null であれば、userAgentisomorphic encode されたものとして返す。

  3. デフォルトの `User-Agent` 値 を返す。

ドキュメント`Accept`ヘッダー値は `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8`です。

2.2.3. ステータス

ステータスは、0から999までの整数です。

HTTP/1のstatus-codeをこの概念にマッピングする際の様々な端ケースについては、issue #1156で対応中です。

nullボディステータスは、 ステータスが101、103、204、205、または304の場合です。

OKステータスは、ステータスが200から299までの範囲の場合です。

range status(レンジステータス) は、206 または 416 の ステータス です。

redirect status(リダイレクトステータス) は、301、302、 303、307、または 308 の ステータス です。

2.2.4. ボディ

ボディは次の要素から成ります:

ボディ body複製するには、次の手順を実行します:

  1. « out1, out2 »をbodyストリームに対してteeした結果とする。

  2. bodyストリームout1に設定する。

  3. 他のメンバーはbodyからコピーし、ボディstreamout2のものを返す。

バイト列 bytesボディとして取得するには、安全に抽出したbytesボディを返す。


ボディ body逐次的に読み込むには、アルゴリズムprocessBodyChunk、アルゴリズムprocessEndOfBody、アルゴリズムprocessBodyError、および省略可能なnull/並列キューまたはグローバルオブジェクト taskDestination(デフォルトnull)を与えて、次の手順を実行します。 processBodyChunkバイト列を受け取るアルゴリズム、processEndOfBodyは引数なしアルゴリズム、processBodyErrorは例外を受け取るアルゴリズムでなければなりません。

  1. taskDestinationがnullなら、新しい並列キューの開始の結果をtaskDestinationに設定する。

  2. readerbodyストリームに対してリーダーの取得を実行した結果を格納する。

    この操作で例外はスローされません。

  3. 逐次読み込みループreadertaskDestinationprocessBodyChunkprocessEndOfBodyprocessBodyErrorで実行する。

ReadableStreamDefaultReader オブジェクトreader並列キューまたはグローバルオブジェクト taskDestination、アルゴリズムprocessBodyChunk、アルゴリズムprocessEndOfBody、アルゴリズムprocessBodyErrorを与えて逐次読み込みループを実行するには:

  1. readRequestを次の読取リクエストとする:

    chunk stepschunkを与えて)
    1. continueAlgorithmをnullとする。

    2. chunkUint8Array オブジェクトでなければ、continueAlgorithmを「processBodyErrorTypeErrorを与えて実行する」に設定する。

    3. それ以外の場合:

      1. byteschunkコピーを格納する。

        実装側は可能な限りこのコピーを避ける戦略を推奨します。

      2. continueAlgorithmを次の手順に設定する:

        1. processBodyChunkbytesを与えて実行する。

        2. 逐次読み込みループreadertaskDestinationprocessBodyChunkprocessEndOfBodyprocessBodyErrorで実行する。

    4. fetchタスクをキューcontinueAlgorithmtaskDestinationを与えて実行する。

    close steps
    1. fetchタスクをキューprocessEndOfBodytaskDestinationを与えて実行する。

    error stepseを与えて)
    1. fetchタスクをキューprocessBodyErroreを与え、taskDestinationで実行する。

  2. チャンクの読み取りreaderreadRequestを与えて実行する。

ボディ body完全に読み込むには、アルゴリズムprocessBody、アルゴリズムprocessBodyError、および省略可能なnull/並列キューまたはグローバルオブジェクト taskDestination(デフォルトnull)を与えて、次の手順を実行します。processBodyバイト列を受け取るアルゴリズム、processBodyErrorはオプションで例外を受け取るアルゴリズムでなければなりません。

  1. taskDestinationがnullなら、新しい並列キューの開始の結果をtaskDestinationに設定する。

  2. successStepsバイト列 bytesを受け取り、 fetchタスクをキューprocessBodybytesを与えtaskDestinationで実行する手順とする。

  3. errorStepsを(オプションの例外 exceptionを受け取り) fetchタスクをキューprocessBodyErrorexceptionを与えtaskDestinationで実行する手順とする。

  4. readerbodyストリームに対してリーダーの取得を実行した結果を格納する。例外が発生した場合、errorStepsをその例外で実行し終了する。

  5. 全バイトの読み取りreadersuccessStepserrorStepsを与えて実行する。


型付きボディは、タプルであり、 ボディボディ)と ヘッダー値またはnull)から構成されます。


codingsbytesを与えてコンテンツ符号化の処理を行うには、次の手順を実行します:

  1. codingsがサポートされていなければ、bytesを返す。

  2. HTTPの説明通りにcodingsbytesをデコードした結果(エラーでなければ)を返し、デコードに失敗したらfailureを返す。[HTTP]

2.2.5. リクエスト

この節ではリクエストの詳細な動作を記述します。導入は リクエストのセットアップを参照してください。

fetchの入力はリクエストです。

リクエストには、関連付けられたメソッドメソッド)があります。特に記載がない限り、`GET`です。

これはリダイレクト時にGETへ更新される場合があります。詳細はHTTP fetchを参照。

リクエストには、関連付けられたURLURL)があります。

実装はこれをURLのリストの最初の要素へのポインタとしてもよいです。これはFetchにフックする他仕様の便宜のためだけに独立したフィールドとして提供されています。

リクエストには、関連付けられたローカルURLのみフラグがあります。特に記載がない限り、未設定です。

リクエストには、関連付けられたヘッダーリストヘッダーリスト)があります。特に記載がない限り、« » です。

リクエストには、関連付けられたunsafe-requestフラグがあります。特に記載がない限り、未設定です。

unsafe-requestフラグは、 fetch()XMLHttpRequest などのAPIによって設定され、指定されたメソッドヘッダーリストに基づいて CORSプリフライトフェッチが確実に行われるようにします。 ただし、APIが禁止メソッド禁止リクエストヘッダーを認めない義務から解放されるわけではありません。

リクエストには、関連付けられたボディ(null、バイト列、またはボディ)があります。特に記載がない限り、nullです。

バイト列は、安全に抽出されて早い段階でボディになります。HTTP fetchの一部として、特定のリダイレクトでこのフィールドがnullになる場合があります。


リクエストには、関連付けられたクライアント(nullまたは環境設定オブジェクト)があります。

リクエストには、関連付けられた予約クライアント(null、環境、または環境設定オブジェクト)。特に記載がない限り、nullです。

これはナビゲーションリクエストやワーカーリクエストのみで使われ、サービスワーカリクエストでは使われません。ナビゲーションリクエストでは環境、ワーカーリクエストでは環境設定オブジェクトを参照します。

リクエストには、関連付けられたクライアント置換ID(文字列)があります。特に記載がない限り、空文字列です。

これはナビゲーションリクエストでのみ使われます。IDは、ターゲット閲覧コンテキストアクティブドキュメント環境設定オブジェクトのIDです。

リクエストには、関連付けられたユーザプロンプト用トラバーサブルがあり、 "no-traversable"、"client"、またはトラバーサブルナビゲーブルです。特に記載がない限り"client"です。

これは、認証プロンプトやクライアント証明書ダイアログなど、リクエストに関連するUIを表示するか、どこに表示するかを決定するために使われます。

"no-traversable"
UIは表示されません。通常、このリクエストはネットワークエラーで失敗します。
"client"
この値は、トラバーサブルナビゲーブルまたは"no-traversable"にfetch処理中に自動的に変更されます。これによって他の標準仕様が明示的に設定しなくても済みます。
トラバーサブルナビゲーブル
表示されるUIは、そのトラバーサブルナビゲーブルを表示しているブラウザインターフェース要素に関連付けられます。

リクエストに関連するユーザーインターフェースをそのリクエストのユーザプロンプト用トラバーサブルで表示する場合、ユーザーエージェントはアドレスバーをリクエストの現在のURLに由来する値(例えば、リクエストの発起元のURLではなく)で更新すべきです。また、特にクロスオリジンリクエストの場合、ユーザーエージェントはプロンプトの背後にリクエストの発起元コンテンツを表示しないようにすべきです。このようなプロンプトの背後は空白ページにするのがよいでしょう。これらの指針に従わないと、どのオリジンがプロンプトの責任を持つのかユーザーが混乱します。

リクエストには、関連付けられたboolean型のkeepaliveがあります。特に記載がない限り、falseです。

これは、例えばnavigator.sendBeacon()やHTMLのimg要素のように、リクエストが環境設定オブジェクトより長寿命になることを許可するために使われます。これがtrueの場合、追加の処理要件が課されます。

リクエストには、関連付けられたinitiator typeがあり、null、"audio"、"beacon"、"body"、"css"、"early-hints"、"embed"、"fetch"、"font"、"frame"、"iframe"、"image"、"img"、"input"、"link"、"object"、"ping"、"script"、"track"、"video"、"xmlhttprequest"、"other"のいずれかです。特に記載がない限りnullです。[RESOURCE-TIMING]

リクエストには、関連付けられたservice-workersモードがあり、"all"または"none"です。特に記載がない限り、"all"です。

これは、このフェッチに対してどのサービスワーカーがfetchイベントを受け取るかを決定します。

"all"
関連するサービスワーカーはこのフェッチに対するfetchイベントを受け取ります。
"none"
どのサービスワーカーもこのフェッチに対してイベントを受け取りません。

リクエストには、関連付けられたinitiatorがあり、空文字列、"download"、"imageset"、"manifest"、"prefetch"、"prerender"、または"xslt"のいずれかです。特に記載がない限り空文字列です。

リクエストinitiatorは今のところあまり細かく分かれていません。他の仕様がそれを必要としていないためです。これは主にCSPや混在コンテンツを定義するための仕様上の補助的な属性です。JavaScriptには公開されません。[CSP] [MIX]

destination typeは、空文字列、"audio"、"audioworklet"、"document"、"embed"、"font"、"frame"、"iframe"、"image"、"json"、"manifest"、"object"、"paintworklet"、"report"、"script"、"serviceworker"、"sharedworker"、"style"、"track"、"video"、"webidentity"、"worker"、または"xslt"のいずれかです。

リクエストには、関連付けられたdestinationdestination type)があります。特に記載がない限り空文字列です。

これらはRequestDestinationで反映されますが、"serviceworker"と"webidentity"は該当しません。これらのdestinationではサービスワーカーをスキップします。

リクエストdestinationscript-likeとなるのは、"audioworklet"、"paintworklet"、"script"、"serviceworker"、"sharedworker"、または"worker"の場合です。

script-likeを利用するアルゴリズムは、"xslt"もスクリプト実行の原因となり得るため考慮すべきです。ただし、常に該当するとは限らず異なる動作が必要な場合があるためリストには含まれていません。

次の表は、リクエストinitiatordestination、CSPディレクティブ、および各機能との関係を示しています。機能については網羅的ではありません。各機能は、それぞれの現行標準で関連値を定義する必要があります。

Initiator Destination CSPディレクティブ 機能
"" "report" CSP、NELレポート
"document" HTMLのnavigateアルゴリズム(トップレベルのみ)
"frame" child-src HTMLの<frame>
"iframe" child-src HTMLの<iframe>
"" connect-src navigator.sendBeacon()EventSource、 HTMLの<a ping="">および<area ping="">fetch()fetchLater()XMLHttpRequestWebSocketWebTransport、 Cache API
"object" object-src HTMLの<object>
"embed" object-src HTMLの<embed>
"audio" media-src HTMLの<audio>
"font" font-src CSSの@font-face
"image" img-src HTMLの<img src>/favicon.icoリソース、 SVGの<image>、CSSのbackground-image、CSSの cursor、CSSのlist-style-image、…
"audioworklet" script-src audioWorklet.addModule()
"paintworklet" script-src CSS.paintWorklet.addModule()
"script" script-src HTMLの<script>importScripts()
"serviceworker" child-srcscript-srcworker-src navigator.serviceWorker.register()
"sharedworker" child-srcscript-srcworker-src SharedWorker
"webidentity" connect-src Federated Credential Management requests
"worker" child-srcscript-srcworker-src Worker
"json" connect-src import "..." with { type: "json" }
"style" style-src HTMLの<link rel=stylesheet>、CSSの@importimport "..." with { type: "css" }
"track" media-src HTMLの<track>
"video" media-src HTMLの<video>要素
"download" "" HTMLのdownload=""、"リンク先を名前を付けて保存…" UI
"imageset" "image" img-src HTMLの<img srcset><picture>
"manifest" "manifest" manifest-src HTMLの<link rel=manifest>
"prefetch" "" default-src(特定ディレクティブなし) HTMLの<link rel=prefetch>
"prerender" HTMLの<link rel=prerender>
"xslt" "xslt" script-src <?xml-stylesheet>

CSPのform-actionはHTMLのnavigateやフォーム送信アルゴリズムに直接フックする必要があります。

CSPはまた、リクエストクライアントグローバルオブジェクト対応するDocument祖先ナビゲーブルも、さまざまなCSPディレクティブで確認する必要があります。


リクエストには、関連付けられた priorityがあり、"high"、"low"、"auto"のいずれかです。特に記載がない限り"auto"です。

リクエストには、関連付けられた 内部priority(nullまたは 実装依存オブジェクト)があります。特に記載がない限りnullです。

リクエストには、関連付けられた originがあり、 "client"またはオリジンです。特に記載がない限り"client"です。

"client"はオリジンにfetch処理中に変更されます。これにより、他の標準が リクエストoriginを明示的に設定しなくても済みます。

リクエストには、関連付けられた トップレベルナビゲーションinitiatorのoriginがあり、 オリジン またはnullです。特に記載がない限りnullです。

リクエストには、関連付けられた ポリシーコンテナがあり、 "client"またはポリシーコンテナです。特に記載がない限り"client"です。

"client"はポリシーコンテナにfetch処理中に変更されます。これにより、他の標準が リクエストポリシーコンテナを明示的に設定しなくても済みます。

リクエストには、関連付けられた referrerがあり、 "no-referrer"、"client"またはURLです。特に記載がない限り "client"です。

"client"はfetch処理中に"no-referrer"またはURLに変更されます。これにより、他の標準が リクエストreferrerを明示的に設定しなくても済みます。

リクエストには、関連付けられた referrer policyがあり、 referrer policyです。特に記載がない限り空文字列です。[REFERRER]

これは、このリクエストに使うreferrer policyを上書きするために使えます。

リクエストには、 関連付けられた mode(モード)が存在します。これは "same-origin"、"cors"、"no-cors"、 "navigate"、"websocket" または "webtransport" のいずれかです。 特に指定がない限り、"no-cors" です。

"same-origin"
同一オリジンのURLへのリクエストを保証するために使われます。fetchは、リクエストが同一オリジンURLでない場合、ネットワークエラーを返します。
"cors"
レスポンスタインティングが"cors"に設定されるリクエストの場合、このリクエストをCORSリクエストとし、リソースがCORSプロトコルに対応しなかったり、意図的に不参加の場合はネットワークエラーを返します。
"no-cors"
CORSセーフリストメソッドおよびCORSセーフリストリクエストヘッダーのみ利用可能に制限。成功時はopaque filtered responseを返します。
"navigate"
これは、ドキュメントのナビゲーション時にのみ使われる特別なモードです。
"websocket"
これは、WebSocket接続の確立時にのみ使われる特別なモードです。
"webtransport"
これは、WebTransport(url, options)のみで使用される特別なモードです。

デフォルトのリクエストmodeは"no-cors"ですが、新しい機能ではこれを使わないことが強く推奨されます。これは非常に安全ではありません。

リクエストには、関連付けられた use-CORS-preflightフラグがあります。特に記載がない限り、未設定です。

use-CORS-preflightフラグが設定されている場合、CORSプリフライトリクエストとなる条件の一つです。このフラグは、XMLHttpRequestUpload オブジェクトに1つ以上のイベントリスナーが登録されている場合や、リクエストにReadableStream オブジェクトが使用されている場合に設定されます。

リクエストには、関連付けられた credentials modeがあり、 "omit"、"same-origin"、"include"のいずれかです。特に記載がない限り、"same-origin"です。

"omit"
このリクエストから認証情報(credentials)を除外し、レスポンスで送信された認証情報も無視します。
"same-origin"
同一オリジンのURLへのリクエストには認証情報を含め、同一オリジンからのレスポンスの認証情報も利用します。
"include"
常にこのリクエストに認証情報を含め、レスポンスに含まれる認証情報も常に利用します。

リクエストcredentials modeは、認証情報fetch中の流れを制御します。リクエストmodeが"navigate"の場合、そのcredentials modeは"include"とみなされ、fetchは現状他の値を考慮しません。HTML側の仕様変更があれば、この標準も対応が必要です。

リクエストには、関連付けられた use-URL-credentialsフラグがあります。特に記載がない限り、未設定です。

このフラグが設定されている場合、リクエストURLユーザー名パスワードがあり、利用可能な認証エントリがある場合、URLの認証情報が認証エントリより優先されます。URLに認証情報を含めることは推奨されていないため、現行の仕様ではこのフラグを設定しないことが多いですが、互換性のため古い機能で設定される場合があります。

リクエストには、関連付けられた cache modeがあり、 "default"、"no-store"、"reload"、"no-cache"、"force-cache"、"only-if-cached"のいずれかです。特に記載がない限り"default"です。

"default"
Fetchはネットワークに行く前にHTTPキャッシュを確認します。HTTPキャッシュに一致する新鮮なレスポンスがあればそれを返します。一致するstale-while-revalidateレスポンスがあればそれを返しつつ条件付きネットワークリクエストを送りキャッシュを更新します。一致する古いレスポンスがあれば条件付きネットワークリクエストを返します。それ以外は非条件付きネットワークリクエストを返します。[HTTP] [HTTP-CACHING] [STALE-WHILE-REVALIDATE]
"no-store"
FetchはHTTPキャッシュがまったく存在しないかのように動作します。
"reload"
Fetchはネットワークに行く前にHTTPキャッシュがないかのように動作します。つまり、通常のリクエストを作成し、レスポンスでHTTPキャッシュを更新します。
"no-cache"
HTTPキャッシュにレスポンスがあれば条件付きリクエストを作成し、なければ通常のリクエストを作成します。その後レスポンスでHTTPキャッシュを更新します。
"force-cache"
Fetchはリクエストに一致するHTTPキャッシュ内のレスポンスを鮮度に関係なく使用します。なければ通常のリクエストを作成し、レスポンスでキャッシュを更新します。
"only-if-cached"
Fetchはリクエストに一致するHTTPキャッシュ内のレスポンスを鮮度に関係なく使用します。なければネットワークエラーを返します(このモードはリクエストmodeが"same-origin"の場合のみ使用可能)。キャッシュされたリダイレクトはリクエストredirect modeが"follow"で、そのリダイレクトがリクエストmodeに違反しない場合にのみ追従されます。

ヘッダーリスト含む `If-Modified-Since`, `If-None-Match`, `If-Unmodified-Since`, `If-Match`, または `If-Range` のいずれかが含まれる場合、fetchcache modeを"default"なら"no-store"に設定します。

リクエストには、関連付けられた redirect modeがあり、 "follow"、"error"、"manual"のいずれかです。特に記載がない限り"follow"です。

"follow"
リソースのフェッチ時に発生したすべてのリダイレクトを追従します。
"error"
リクエストがリダイレクトに遭遇した場合、ネットワークエラーを返します。
"manual"
サービスワーカーがリダイレクトをオフラインで再現できるよう、リダイレクトに遭遇した際にopaque-redirect filtered responseを返します。それ以外はネットワークエラーと区別できません。atomic HTTPリダイレクト処理に違反しないようにしています。

リクエストには、関連付けられた integrity metadata (文字列)があります。特に記載がない限り、空文字列です。

リクエストには、関連付けられた 暗号ノンスmetadata (文字列)があります。特に記載がない限り、空文字列です。

リクエストには、関連付けられた パーサmetadata (空文字列、"parser-inserted"、または"not-parser-inserted")があります。特に記載がない限り、空文字列です。

リクエスト暗号ノンスmetadataおよびパーサmetadataは、通常、リクエストを生成したHTML要素の属性やフラグから設定されます。これらはContent Security Policyの様々なアルゴリズムで、リクエストやレスポンスが特定のコンテキストでブロックされるかどうかの判定に使われます。[CSP]

リクエストには、関連付けられた reload-navigationフラグがあります。特に記載がない限り、未設定です。

このフラグはHTMLのnavigateアルゴリズム専用です。[HTML]

リクエストには、関連付けられた history-navigationフラグがあります。特に記載がない限り、未設定です。

このフラグはHTMLのnavigateアルゴリズム専用です。[HTML]

リクエストには、関連付けられた boolean型のuser-activationがあります。特に記載がない限り、falseです。

これはHTMLのnavigateアルゴリズム専用です。[HTML]

リクエストには、関連付けられた boolean型のrender-blockingがあります。特に記載がない限り、falseです。

このフラグはHTMLのrender-blockingメカニズム専用です。[HTML]

リクエスト には、 WebTransport-ハッシュリスト (WebTransport-ハッシュリスト) が関連付けられている。特に記載がない限り、これは « » である。

WebTransport-ハッシュリスト とは、 0個以上の リスト であり、 WebTransport-ハッシュ の集まりである。

WebTransport-ハッシュ とは、 タプル であり、 アルゴリズム文字列)と、 バイト列) から構成される。

このリストは、 WebTransport(url, options)optionsserverCertificateHashes を含む際の排他的な利用のためのものである。


リクエスト には、 URLリスト(1個以上の リストURLの集まり)が関連付けられている。特に記載がない場合、リストには リクエストURL のコピーが含まれる。

リクエスト には、 現在のURL が関連付けられている。それは リクエストURLリスト 内の最後の URL を指すポインタである。

リクエスト には、 リダイレクト回数 が関連付けられている。 特に記載がない場合、これは0である。

リクエスト には、 レスポンス汚染 が関連付けられている。 これは"basic"、"cors"、または"opaque"のいずれかである。 特に記載がなければ"basic"である。

リクエスト には、 no-cacheキャッシュ制御ヘッダー変更防止フラグ が関連付けられている。 特に記載がない場合、未設定である。

リクエスト には、 完了フラグ が関連付けられている。 特に記載がない場合、未設定である。

リクエスト には、 タイミング許可失敗フラグ が関連付けられている。特に 記載がなければ未設定である。

リクエストURLリスト現在のURLリダイレクト回数レスポンス汚染完了フラグ、および タイミング許可失敗フラグ は、fetch アルゴリズムの帳簿的詳細で使用される。


サブリソースリクエストとは、 リクエストのうち、 destination が "audio"、 "audioworklet"、 "font"、"image"、"json"、"manifest"、 "paintworklet"、"script"、"style"、"track"、 "video"、"xslt"、または空文字列のものをいう。

非サブリソースリクエストとは、 リクエストのうち、 destination が "document"、"embed"、 "frame"、"iframe"、"object"、"report"、 "serviceworker"、"sharedworker"、"worker" のいずれかのものをいう。

ナビゲーションリクエストとは、 リクエストのうち、 destination が "document"、"embed"、"frame"、"iframe"、 または "object" のものをいう。

これらの用語の使用例は handle fetch を参照。 [SW]


リクエスト requestリダイレクト汚染度 を計算するには、以下の手順を実行する。戻り値は "same-origin"、"same-site"、または"cross-site" である。

  1. 確認: requestorigin は "client" ではない。

  2. lastURL を null にする。

  3. taint を "same-origin" にする。

  4. requestURLリストurl ごとに:

    1. もし lastURL が null ならば、lastURLurl を設定し、 次へ 続行。

    2. もし urloriginlastURLoriginsame site でなく、かつ requestoriginlastURLoriginsame site でなければ、"cross-site" を返す。

    3. もし urloriginlastURLoriginsame origin でなく、 かつ requestoriginlastURLoriginsame origin でなければ、 taint を "same-site" にする。

    4. lastURLurl を設定する。

  5. taint を返す。

リクエストオリジンの直列化 は、リクエスト request を引数とし、以下の手順を実行する:

  1. 確認: requestorigin は "client" ではない。

  2. requestリダイレクト汚染度 が "same-origin" でなければ、"null" を返す。

  3. requestoriginASCII直列化 して返す。

リクエストオリジンのバイト直列化リクエスト request を引数とし、リクエストオリジンの直列化request で実行し、 等価エンコード した結果を返す。


リクエスト request複製するには、次の手順を実行する:

  1. newRequestrequest のコピーを作成するが、 body は除く。

  2. requestbody が null でなければ、 newRequestbodyクローン結果を設定する。

  3. newRequest を返す。


リクエスト request にレンジヘッダーを 追加するには、整数 first とオプションの整数 last を引数として、次の手順を実行する:

  1. 確認: last が指定されていなければ、または firstlast 以下であること。

  2. rangeValuebytes= をセット。

  3. 整数を直列化して 等価エンコードしたfirstrangeValue に追加。

  4. 0x2D (-) を rangeValue に追加。

  5. last が与えられていれば、 直列化等価エンコードし、rangeValue に追加。

  6. Append (`Range`, rangeValue) を requestヘッダーリスト に追加。

レンジヘッダーは包括的なバイト範囲を示す。 first が 0、last が 500 の場合、範囲は 501 バイトとなる。

複数のレスポンスを1つの論理リソースへまとめる機能は、歴史的に セキュリティバグの原因となってきた。部分レスポンスを扱う機能を設計する際は 必ずセキュリティレビューを受けてください。


レスポンス response について、 報告用にレスポンスURLを直列化するには、次の手順を実行する:

  1. 確認: responseURLリスト空ではないこと。

  2. urlresponseURLリスト[0] のコピーをセット。

    これはresponseURL ではなく リダイレクト先の情報漏えいを防ぐためである(CSP報告についても 同様の考慮を参照)。 [CSP]

  3. ユーザー名を設定 し、url に空文字列をセット。

  4. パスワードを設定 し、url に空文字列をセット。

  5. 直列化し、 フラグメント除外 を true にして返す。

Cross-Origin-Embedder-Policy が認証情報を許可するか確認する には、 リクエスト request を与え、次の手順を実行する:

  1. 確認: requestorigin は "client" ではない。

  2. requestmode が "no-cors" でなければ true を返す。

  3. requestclient が null であれば true を返す。

  4. requestclientポリシーコンテナエンベッダーポリシー が "credentialless" でなければ true を返す。

  5. requestoriginrequest現在のURLoriginリダイレクト汚染度 が "same-origin" でなければ true を返す。

  6. false を返す。

2.2.6. レスポンス

fetchの結果はレスポンスです。レスポンスは時間とともに変化します。つまり、すべてのフィールドがすぐに利用できるとは限りません。

レスポンスには、関連付けられたtypeがあります。 "basic"、 "cors"、 "default"、 "error"、 "opaque"、または "opaqueredirect"。 特に記載がない限り、"default"です。

レスポンスには、関連付けられたabortedフラグがあります。初期値は未設定です。

これはリクエストが開発者またはエンドユーザーによって意図的に中断されたことを示します。

レスポンスには、関連付けられたURLがあります。これはURLのリストの最後の要素を指します。レスポンスURLリストの場合はnullです。

レスポンスには、関連付けられたURLリストURLのリスト、0個以上)があります。特に記載がない限り、« »です。

1つ目と最後のURL以外は、レスポンスURLリストはスクリプトに直接公開されません。これはアトミックなHTTPリダイレクト処理に反するからです。

レスポンスには、関連付けられたstatusステータス)があります。特に記載がない限り200です。

レスポンスには、関連付けられたstatus messageがあります。特に記載がない限り、空のバイト列です。

HTTP/2接続上のレスポンスは常に空のバイト列をstatus messageとします。HTTP/2ではサポートされていません。

レスポンスには、関連付けられたヘッダーリストヘッダーリスト)があります。特に記載がない限り、« »です。

レスポンスには、関連付けられたボディ(nullまたはボディ)があります。特に記載がない限り、nullです。

ネットワーク由来のレスポンスボディについては、sourceおよびlengthの概念は常にnullです。

レスポンスには、関連付けられたキャッシュ状態(空文字列、"local"、"validated")があります。特に記載がない限り空文字列です。

これは Service Workers および Resource Timing による使用を意図しています。[SW] [RESOURCE-TIMING]

レスポンスには、関連付けられたCORS公開ヘッダー名リスト(0個以上のヘッダー名前のリスト)があります。特に記載がない限り空です。

レスポンスCORS公開ヘッダー名リストは通常、`Access-Control-Expose-Headers`ヘッダーからヘッダー値を抽出して設定されます。このリストはCORSフィルタ済みレスポンスが公開するヘッダーを決定するのに使われます。

レスポンスには、関連付けられたrange-requestedフラグがあります。初期値は未設定です。

これは、事前の範囲リクエストによる部分レスポンスが、範囲リクエストを行っていないAPIに提供されるのを防ぐために使われます。攻撃の詳細な説明についてはフラグの使われ方を参照してください。

レスポンスには、関連付けられたrequest-includes-credentials (boolean型)があります。初期値はtrueです。

レスポンスには、関連付けられたtiming allow passedフラグがあります。初期値は未設定です。

これはfetchの呼び出し元が、取得したリソースに対してセンシティブなタイミングデータが許可されているかをレスポンスのフラグで判定できるようにするためです。リダイレクトチェーン上の前のレスポンスでこのフラグが設定されていた場合、リダイレクトされたレスポンスにも引き継がれるため、リクエストのtiming allow failedフラグでも内部追跡されます。

レスポンスには、関連付けられたbody inforesponse body info)があります。特に記載がない限り、新しいresponse body infoです。

レスポンスには、関連付けられたservice worker timing info(nullまたはservice worker timing info)があります。初期値はnullです。

レスポンスには、関連付けられたredirect taint ("same-origin"、"same-site"、"cross-site")があります。初期値は"same-origin"です。


ネットワークエラーとは、レスポンスであり、そのtypeが"error"、statusが0、status messageが空のバイト列、ヘッダーリストが« »、ボディがnull、body infoが新しいresponse body infoであるものです。

中断されたネットワークエラーとは、ネットワークエラーであって、abortedフラグが設定されているものです。

fetch params fetchParamsを与えて適切なネットワークエラーを作るには:

  1. Assert: fetchParamscanceledであること。

  2. fetchParamsabortedなら中断されたネットワークエラーを、それ以外ならネットワークエラーを返す。


フィルタ済みレスポンスとは、関連付けられたレスポンスへの限定的なビューを提供するレスポンスです。この関連するレスポンスは、フィルタ済みレスポンス内部レスポンスネットワークエラーフィルタ済みレスポンスでないレスポンス)としてアクセスできます。

特に記載がない限り、フィルタ済みレスポンスの各概念(例:ボディ)は、内部レスポンスの対応する概念を参照します(例外はこの後、フィルタ済みレスポンスの具体的な型の定義部分で記載)。

fetchアルゴリズムは、processResponseや同等のパラメータを通じて、呼び出し元にフィルタ済みレスポンスを公開し、情報が誤って漏れないようにしています。レガシー理由で情報を公開する必要がある場合(例:デコーダーに画像データを渡す)、内部レスポンスを仕様アルゴリズムで利用できます。

新しい仕様では、opaqueフィルタ済みレスポンスopaque-redirectフィルタ済みレスポンスを拡張しないようにしてください。これらはレガシーな構造であり、現代のコンピュータアーキテクチャにおいて十分に保護できるとは限りません。

basicフィルタ済みレスポンスは、フィルタ済みレスポンスであり、typeが"basic"で、内部レスポンスヘッダーリストに含まれるヘッダーのうち、禁止レスポンスヘッダー名であるものを除外したものです。

CORSフィルタ済みレスポンスは、フィルタ済みレスポンスであり、typeが"cors"で、内部レスポンスヘッダーリストに含まれるヘッダーのうち、CORSセーフリストレスポンスヘッダー名内部レスポンスCORS公開ヘッダー名リストを与える)でないものを除外したものです。

opaqueフィルタ済みレスポンスは、フィルタ済みレスポンスであり、typeが"opaque"、URLリストが« »、statusが0、status messageが空のバイト列、ヘッダーリストが« »、ボディがnull、body infoが新しいresponse body infoです。

opaque-redirectフィルタ済みレスポンスは、 フィルタ済みレスポンスであって、 typeが"opaqueredirect"、 statusが0、 status messageが空のバイト列、 ヘッダーリストが« »、 ボディがnull、 そして body infoが新しい response body info であるものです。

URLリストopaque-redirectフィルタ済みレスポンスで公開しても、リダイレクトは辿られないため問題ありません。

言い換えると、opaqueフィルタ済みレスポンスopaque-redirectフィルタ済みレスポンスネットワークエラーとほとんど区別がつきません。 新しいAPIを導入する際は、内部レスポンスを内部仕様アルゴリズムで使わないでください。情報漏えいにつながります。

これはまた、response.okのようなJavaScript APIの結果がほとんど役に立たないことも意味します。

typeレスポンスtype getterを通じてスクリプトに公開されます:

console.log(new Response().type); // "default"

console.log((await fetch("/")).type); // "basic"

console.log((await fetch("https://api.example/status")).type); // "cors"

console.log((await fetch("https://crossorigin.example/image", { mode: "no-cors" })).type); // "opaque"

console.log((await fetch("/surprise-me", { redirect: "manual" })).type); // "opaqueredirect"

(これは各リソースが存在し、https://api.example/statusが適切なCORSヘッダーを持ち、/surprise-meリダイレクトステータスを使用していることを前提とします。)


レスポンス response複製するには、次の手順を実行します:

  1. responseフィルタ済みレスポンスであれば、内部レスポンスresponse内部レスポンス複製である、新しい同一のフィルタ済みレスポンスを返す。

  2. newResponseresponseのコピー(ただしボディを除く)とする。

  3. responseボディがnullでなければ、newResponseボディ複製したresponseボディを設定する。

  4. newResponseを返す。


新鮮なレスポンスは、 レスポンスであって、 現在エージが、その 鮮度寿命以内であるものです。

stale-while-revalidateレスポンスは、 レスポンスであって、 新鮮なレスポンスでなく、 現在エージstale-while-revalidate寿命以内であるものです。 [HTTP-CACHING] [STALE-WHILE-REVALIDATE]

古いレスポンスは、 レスポンスであって、 新鮮なレスポンスでも stale-while-revalidateレスポンスでもないものです。


レスポンス responselocation URLは、 nullまたはASCII文字列 requestFragmentを与えて、 次の手順で決定されます。返り値はnull・failure・またはURLです。

  1. responsestatusリダイレクトステータスでなければnullを返す。

  2. locationヘッダーリスト値を抽出(`Location`・responseヘッダーリスト)の結果とする。

  3. locationヘッダー値なら、 locationパースlocationresponseURL)の結果に置き換える。

    responseResponseコンストラクターで生成された場合、 responseURLはnullとなるため、 location絶対URL+フラグメント文字列でなければパースに成功しません。

  4. locationURLで、 そのfragmentがnullなら、 locationfragmentrequestFragmentを設定する。

    これにより、合成レスポンス(実際には全てのレスポンス)がHTTPで定義されるリダイレクトの処理モデルに従うことが保証されます。[HTTP]

  5. locationを返す。

location URLアルゴリズムは、この標準と、リダイレクトを手動で処理するHTMLのnavigateアルゴリズム専用です。[HTML]

2.2.7. その他

潜在的なdestinationは、"fetch"または空文字列でないdestinationです。

潜在的なdestination potentialDestination変換するには、次の手順を実行します:

  1. potentialDestinationが"fetch"なら空文字列を返す。

  2. Assert: potentialDestinationdestinationであること。

  3. potentialDestinationを返す。

2.3. 認証エントリ

認証エントリおよびプロキシ認証エントリは、ユーザー名・パスワード・レルムからなるタプルであり、HTTP認証およびHTTPプロキシ認証に使われ、1つ以上のリクエストに関連付けられます。

ユーザーエージェントは、認証エントリとHTTPクッキーや同様のトラッキング機能を一括してクリアできるようにすべきです。

詳細はHTTPで定義されています。[HTTP] [HTTP-CACHING]

2.4. Fetchグループ

環境設定オブジェクト には fetch グループ が関連付けられており、これが fetch グループ を保持する。

fetch グループ は フェッチに関する情報を保持する。

fetch グループ には 次のものが関連付けられている:

fetch レコード
リスト であり、 fetch レコード の集まり。
deferred fetch レコード
リスト であり、 deferred fetch レコード の集まり。

fetch レコード とは 以下の項目を持つ 構造体 である:

リクエスト
リクエスト
コントローラー
fetch コントローラー または null。

deferred fetch レコード とは、 後で fetch を呼び出すために必要な状態を維持するために使われる 構造体 であり、例えばドキュメントがアンロードされたり 完全にアクティブでなくなったときなどである。以下の 項目 を持つ:

リクエスト
リクエスト
通知呼び出し済み
引数なしのアルゴリズム。
呼び出し状態 (デフォルト "pending")
"pending"、"sent"、または"aborted"。

fetch グループ fetchGroup終了されるとき:

  1. fetch レコード record について、 fetchGroupfetch レコード を走査し、 もし recordコントローラー が null でなく、 かつ recordリクエスト完了フラグ が未設定 かつ keepalive が false であれば、 終了 recordコントローラー を行う。

  2. deferred fetch を処理 する fetchGroup に対して。

2.5. ドメインの解決

(This is a tracking vector.) ネットワークパーティションキー keyオリジン originを与えて オリジンを解決するには、次の手順を実行します:

  1. originhostIPアドレスであれば、 « originhost » を返す。

  2. originhostパブリックスフィックスが"localhost"または"localhost."であれば、 « ::1, 127.0.0.1 » を返す。

  3. originを1つ以上のIPアドレス集合に変換する 実装依存の操作を行う。

    他にも、IPアドレス以外の 接続情報を取得するために他の操作を行うかどうかも 実装依存です。例えば、 originスキームHTTP(S)スキームの場合、実装はHTTPS RRのためのDNSクエリを行うかもしれません。[SVCB]

    この操作が成功した場合、IPアドレスの集合および 追加の実装依存情報を返す。

  4. failureを返す。

オリジンを解決するの結果はキャッシュしてもよい。キャッシュする場合はkeyをキャッシュキーの一部として用いるべきである。

通常この操作はDNSを伴い、DNSサーバー側でkeyを考慮せずキャッシュされる場合があります。実装によってはローカルでkeyを考慮することもできない場合があります。[RFC1035]

IPアドレスの順序は、 オリジンを解決するアルゴリズムの呼び出しごとに異なる場合があります。

(キャッシュキー以外の)詳細は、Fetch標準が定めるシステムに直接関係しないため拘束されません。他の文書がこのプリミティブに依存して拡張する場合は、まずFetch標準コミュニティと十分に議論するべきです。

2.6. コネクション

ユーザーエージェントは、関連付けられたコネクションプールを持ちます。 コネクションプールは、 0個以上の順序付き集合としてのコネクションです。各コネクションは、関連付けられたキーネットワークパーティションキー)、 オリジンオリジン)、および認証情報 (boolean)で識別されます。

コネクションは、関連付けられた タイミング情報コネクションタイミング情報)を持ちます。

コネクションタイミング情報は、 コネクション取得処理に関するタイミング情報を保持するための 構造体です。以下の項目があります:

ドメインルックアップ開始時刻(初期値0)
ドメインルックアップ終了時刻(初期値0)
コネクション開始時刻(初期値0)
コネクション終了時刻(初期値0)
セキュアコネクション開始時刻(初期値0)
DOMHighResTimeStamp
ALPNネゴシエートプロトコル(初期値:空のバイト列
バイト列

コネクションタイミング情報のclampおよびcoarsenを行うには、 コネクションタイミング情報 timingInfoDOMHighResTimeStamp defaultStartTime、boolean crossOriginIsolatedCapabilityを与えて次の手順を実行する:

  1. timingInfoコネクション開始時刻defaultStartTimeより小さければ、新しいコネクションタイミング情報を返す(全ての時刻がdefaultStartTime、ALPNネゴシエートプロトコルはtimingInfoの値)。

  2. 新しいコネクションタイミング情報を返す(各時刻はcoarsen timeの結果、ALPNネゴシエートプロトコルはtimingInfoの値)。


新規コネクション設定は、"no"、"yes"、"yes-and-dedicated"のいずれかです。

コネクションを取得するには、 ネットワークパーティションキー keyURL url、 真偽値 credentials、オプションの 新規コネクション設定 new(デフォルトは"no")、 オプションの真偽値 requireUnreliable(デフォルトはfalse)、 そしてオプションの WebTransport-ハッシュリスト webTransportHashes(デフォルトは « »)を与え、次の手順を行う:

  1. もし new が"no"ならば:

    1. 確認: webTransportHashes空であること。

    2. connections を、ユーザーエージェントの コネクションプール内の、 keykeyoriginurloriginであり、 credentialscredentials である コネクション の集合とする。

    3. もし connections が空でなく、かつ requireUnreliable がfalseならば、 connections のいずれか1つを返す。

    4. もし connections 内に非信頼性トランスポートを サポートできるコネクション(例:HTTP/3)があるなら そのコネクションを返す。

  2. proxies を、urlに対し実装依存の方法でプロキシを探索した結果とする。プロキシがない場合、proxies は « "DIRECT" » とする。

    ここで非標準技術( WPADPAC)が活用されることがある。 "DIRECT" はこの url へプロキシを使用しないことを意味する。

  3. timingInfo を新しい コネクションタイミング情報にする。

  4. proxiesproxy について:

    1. timingInfoドメインルックアップ開始時刻非安全な共有現在時刻で設定。

    2. hosts を « urloriginhost » とする。

    3. もし proxy が "DIRECT" ならば オリジンの解決key, urlorigin で実行した結果を hosts に設定する。

    4. もし hosts が失敗ならば 次へ

    5. timingInfoドメインルックアップ終了時刻非安全な共有現在時刻 で設定。

    6. connection を、次を実行した結果とする:コネクション作成key, urlorigin, credentials, proxy実装依存hosthostsより)、 timingInforequireUnreliablewebTransportHashes を用い、実装依存の回数だけ並列で実行し、1つ以上値が返るまで待ち、実装依存な方法で返ってきた値から1つを選んで返す。他の返り値がコネクションだった場合は閉じてもよい。

      本質的にこれは、実装がproxy が "DIRECT" の場合には オリジン解決の戻り値から IPアドレス を選択し、それらでレースしたり、IPv6優先、タイムアウト時再試行等も許容することを意味する。

    7. もし connection が失敗ならば 次へ

    8. もし new が"yes-and-dedicated"でなければ 追加connection をユーザーエージェントのコネクションプールに追加する。

    9. connection を返す。

  5. 失敗を返す。

意図的に曖昧にしてある。なぜならコネクション管理には実装依存の微妙な違いが多数あるためだ。記述があることで <link rel=preconnect> の特徴や、 コネクションが credentials をキーにすることが明確になり、 たとえば TLS セッション識別子が credentials false の コネクションと、 true のコネクションで使い回されないことが明確になる。


コネクションを作成するには、 ネットワークパーティションキー keyオリジン origin、 真偽値 credentials、文字列 proxyホスト hostコネクションタイミング情報 timingInfo、 真偽値 requireUnreliable、および WebTransport-ハッシュリスト webTransportHashes を与え、次の手順を行う:

  1. timingInfoコネクション開始時刻非安全な共有現在時刻 で設定する。

  2. connection を新しい コネクション とし、 keykeyoriginorigincredentialscredentialsタイミング情報timingInfoとする。 コネクションタイミング情報記録connection に用い、 connection でHTTPコネクションをhostに確立する。proxyoriginを考慮しつつ、以下の注意点を踏まえる: [HTTP] [HTTP1] [TLS]

    • もし requireUnreliable が true ならば、非信頼性トランスポート(例えばHTTP/3)が可能なコネクションを確立すること。[HTTP3]

    • 非信頼性トランスポートが可能なコネクションを確立する際は、WebTransport用に必要なオプションを有効化する。 HTTP/3の場合、初期のSETTINGSフレームで SETTINGS_ENABLE_WEBTRANSPORT=1H3_DATAGRAM=1 を含めること。 [WEBTRANSPORT-HTTP3] [HTTP3-DATAGRAM]

    • もし credentials が false なら、TLSクライアント証明書を送信しない。

    • もし webTransportHashes空でない場合は、デフォルトの証明書検証アルゴリズムの代わりに サーバ証明書が 独自証明書要件を満たし、 かつ 証明書ハッシュの検証webTransportHashesが真であるときのみサーバ証明書を有効とみなす。 いずれかの条件を満たさなければ失敗を返す。

    • 接続確立が成功しなかった場合(UDP/TCP/TLSエラー等)は、失敗を返す。

  3. timingInfoALPN交渉済みプロトコルconnection の ALPN Protocol ID で設定。ただし以下の注意点がある: [RFC7301]

    • プロキシ経由時にトンネル接続が成立した場合はトンネル先のプロトコルのALPN Protocol ID、 それ以外は最初のプロキシへのALPN Protocol ID を使うこと。

    • ユーザーエージェントが実験的または未登録プロトコルを使う場合は、使用したALPN Protocol IDがあればそれを使う。 ALPN を使わなかった場合は実装で説明的な文字列を使ってもよい。

      timingInfoALPN交渉済みプロトコル は 実際の交渉方法に関わらず実際に使用するネットワークプロトコルを識別するためのものであり、 ALPNによるネゴシエーションがなくても利用中のプロトコルを示すALPN Protocol IDである。

    IANAは ALPN Protocol IDのリストを管理している。

  4. connection を返す。


コネクションタイミング情報記録は、 コネクション connectionを受け取り、 timingInfoconnectionタイミング情報として次を満たすこと:

コネクションタイミング情報のclampおよびcoarsenアルゴリズムは、再利用コネクションの詳細やタイム値の丸めを保証します。

2.7. ネットワークパーティションキー

ネットワークパーティションキーは、サイトと、nullまたは実装依存の値からなるタプルです。

environment environmentを与え、ネットワークパーティションキーを決定するには、次の手順を実行します:

  1. topLevelOriginenvironmentトップレベルオリジンとする。

  2. topLevelOriginがnullなら、topLevelOriginenvironmentトップレベル生成URLオリジンとする。

  3. Assert: topLevelOriginオリジンである。

  4. topLevelSitetopLevelOriginを与えてサイト取得の結果とする。

  5. secondKeyをnullまたは実装依存の値とする。

    second keyは意図的に曖昧にされています。詳細は今後詰められます。issue #1035参照。

  6. (topLevelSite, secondKey)を返す。

ネットワークパーティションキーを決定するには、 リクエスト request を与え:

  1. もし request予約クライアント が null でなければ、 request予約クライアント を与えて ネットワークパーティションキーを決定する の結果を返す。

  2. もし requestクライアント が null でなければ、 requestクライアント を与えて ネットワークパーティションキーを決定する の結果を返す。

  3. null を返す。

2.8. HTTPキャッシュパーティション

HTTPキャッシュパーティションを決定するには、リクエスト request を与え:

  1. keyネットワークパーティションキーを決定する (request を与える) の結果とする。

  2. もし key が null ならば null を返す。

  3. key に関連付けられたユニークなHTTPキャッシュを返す。[HTTP-CACHING]

2.9. ポートブロッキング

新しいプロトコルはALPNを使い、 TLSハンドシェイク中にプロトコルをネゴシエートすることで ポート遮断の必要性を回避できる。この場合、プロトコルは HTTPリクエストを通じて偽装することができない。 [RFC7301]

あるリクエスト request について 悪いポートのためブロックされるべきかどうか判定するには:

  1. urlrequest現在のURL とする。

  2. もし urlスキームHTTP(S)スキーム であり、 urlポート悪いポート であれば、blocked を返す。

  3. allowed を返す。

ポートが 次の表の最初の列に記載されている場合、悪いポートです。

ポート 主なサービス
0 —​
1 tcpmux
7 echo
9 discard
11 systat
13 daytime
15 netstat
17 qotd
19 chargen
20 ftp-data
21 ftp
22 ssh
23 telnet
25 smtp
37 time
42 name
43 nicname
53 domain
69 tftp
77 —​
79 finger
87 —​
95 supdup
101 hostname
102 iso-tsap
103 gppitnp
104 acr-nema
109 pop2
110 pop3
111 sunrpc
113 auth
115 sftp
117 uucp-path
119 nntp
123 ntp
135 epmap
137 netbios-ns
139 netbios-ssn
143 imap
161 snmp
179 bgp
389 ldap
427 svrloc
465 submissions
512 exec
513 login
514 shell
515 printer
526 tempo
530 courier
531 chat
532 netnews
540 uucp
548 afp
554 rtsp
556 remotefs
563 nntps
587 submission
601 syslog-conn
636 ldaps
989 ftps-data
990 ftps
993 imaps
995 pop3s
1719 h323gatestat
1720 h323hostcall
1723 pptp
2049 nfs
3659 apple-sasl
4045 npp
4190 sieve
5060 sip
5061 sips
6000 x11
6566 sane-port
6665 ircu
6666 ircu
6667 ircu
6668 ircu
6669 ircu
6679 osaut
6697 ircs-u
10080 amanda

2.10. responserequestへのレスポンスとしてMIMEタイプのためにブロックすべきか?

次の手順を実行する:

  1. mimeTypeを、responseヘッダーリストからMIMEタイプ抽出した結果とする。

  2. mimeTypeがfailureなら、allowedを返す。

  3. destinationrequestdestinationとする。

  4. destinationスクリプト系で、以下のいずれかが真ならblockedを返す:

  5. allowedを返す。

3. HTTP拡張

3.1. Cookie

`Cookie`リクエストヘッダーおよび`Set-Cookie`レスポンスヘッダーは主にそれぞれの仕様で定義されています。ここでは、それらを便利に利用できるよう補助的なインフラを定義します。[COOKIES]

リクエストの `Cookie` ヘッダーを付加する には、 リクエスト request を与え:

  1. ユーザーエージェントが request に対して Cookie を無効化している場合、何もせず戻る。

  2. sameSite same-site モード判定 request を与える)の結果とする。

  3. isSecure を、 request現在のURLスキーム が "https" なら true、 そうでなければ false とする。

  4. httpOnlyAllowed を true とする。

    これは fetch から呼ばれるため true である。 例として document.cookie の getter から呼ぶ場合などとは対照的である。

  5. cookiescookie取得isSecure, request現在のURLホスト, request現在のURLパス, httpOnlyAllowed, sameSite を与えて実行した結果とする。

    クッキーストアはソート済みのクッキーリストを返す

  6. もし cookies なら、何もせず戻る。

  7. valueクッキー直列化cookies を与えて実行した結果とする。

  8. 追加 (`Cookie`, value) を requestヘッダーリスト に追加。

レスポンスの `Set-Cookie` ヘッダーを解析して保存する には、 リクエスト request および レスポンス response を与え:

  1. ユーザーエージェントが request に対して Cookie を無効化している場合、何もせず戻る。

  2. allowNonHostOnlyCookieForPublicSuffix を false とする。

  3. isSecure を、 request現在のURLスキーム が "https" なら true、 そうでなければ false とする。

  4. httpOnlyAllowed を true とする。

    これは fetch から呼ばれているため true となる。 例えば document.cookie の getter とは異なる。

  5. sameSiteStrictOrLaxAllowed を、 same-site モード判定 request を与える)の結果が "strict-or-less" なら true、 そうでなければ false とする。

  6. responseヘッダーリストheader について:

    1. もし header名前バイト大小無視 で `Set-Cookie` に一致しなければ、 次へ

    2. クッキーの解析と保存headerisSecurerequest現在のURLホストrequest現在のURLパスhttpOnlyAllowedallowNonHostOnlyCookieForPublicSuffixsameSiteStrictOrLaxAllowed を渡して実行する。

    3. クッキーのガベージコレクトrequest現在のURLホスト で実行する。

    他の場所でも言及されている通り、`Set-Cookie` ヘッダーはまとめて扱えず、 それぞれ個別に処理される。他のどのヘッダーでもこれは許されない。

same-site モードを判定する には、リクエスト request を与え:

  1. 確認: requestメソッド が "GET" または "POST" であること。

  2. もし request トップレベルナビゲーションのイニシエータorigin が null ではなく、かつ requestURLorigin同一サイトでなければ "unset-or-less" を返す。

  3. もし requestメソッド が "GET" で、かつ request送信先 が "document" であれば "lax-or-less" を返す。

  4. もし requestクライアントcross-site な祖先を持つかどうか が true ならば、"unset-or-less" を返す。

  5. もし requestリダイレクト汚染度 が "cross-site" なら、"unset-or-less" を返す。

  6. "strict-or-less" を返す。

「直列化されたCookie既定パス」を得る には、URL url を与え:

  1. cloneURLurl のクローンとする。

  2. cloneURLパス を、 Cookie既定パスcloneURLパスを用いて) に設定する。

  3. cloneURLURLパス直列化 を返す。

3.2. `Origin` ヘッダー

Origin」 リクエストヘッダーは どこからフェッチが発生したかを示す。

Origin」ヘッダーは パス情報を公開しない「Referer」[sic]ヘッダーのバージョンである。 すべてのHTTPフェッチで、 リクエストレスポンス汚染が "cors" である場合や、 リクエストメソッドが `GET` または `HEAD` 以外である場合に使用される。 互換性の都合で、すべてのフェッチに必ず含まれるわけではない。

指定できるは、 リクエストオリジンのバイト直列化リクエストを与える)の戻り値のすべてである。

この仕様はThe Web Origin Conceptの定義を置き換える。 [ORIGIN]


リクエストの `Origin` ヘッダーを付加する には、 リクエスト request を与え、以下の手順を実行する:

  1. 確認requestorigin が "client" ではないこと。

  2. serializedOrigin リクエストオリジンのバイト直列化 request)の結果とする。

  3. もし requestレスポンス汚染 が "cors" であるか、 または requestモード が "websocket" または "webtransport" であれば、 追加 (`Origin`, serializedOrigin) を requestヘッダーリスト に行う。

  4. そうでなく、requestメソッド が `GET` でも `HEAD` でもない場合:

    1. requestモード が "cors" でなければ、 requestreferrer policy を判定しswitch:

      "no-referrer"

      serializedOrigin を `null` に設定。

      "no-referrer-when-downgrade"
      "strict-origin"
      "strict-origin-when-cross-origin"

      もし requestoriginタプルorigin で、 その scheme が "https"、かつ request現在のURLscheme が "https" でない場合、 serializedOrigin を `null` に設定。

      "same-origin"

      もし requestoriginrequest現在のURLorigin同一origin でなければ、 serializedOrigin を `null` に設定。

      その他
      何もしない。
    2. 追加 (`Origin`, serializedOrigin)を requestヘッダーリスト に行う。

リクエスト referrer policy は、CORSプロトコル等で明示的にオリジンをサーバーに共有することを選択していない すべてのフェッチで考慮される。

3.3. CORSプロトコル

レスポンスをオリジン間で共有可能とし、 HTML の form 要素で可能なものよりも柔軟な fetch を許可するために、CORSプロトコル が存在する。 これはHTTP上にレイヤー化されたものであり、レスポンスが他の オリジン と共有できることを宣言できるようにする。

これはファイアウォール(イントラネット)越しにレスポンスのデータ漏洩を防ぐため、 オプトイン機構である必要がある。 また、リクエスト認証情報 を含む場合、機微なデータ漏洩を防ぐためにも オプトインが必要となる。

この節ではサーバ開発者向けに CORSプロトコル を解説する。 ユーザーエージェント向けの要件は fetch アルゴリズムの一部だが 新しいHTTPヘッダー構文を除く。

3.3.1. 一般

CORSプロトコルは、 レスポンスがオリジン間で共有可能かどうかを示す ヘッダー群から成る。

HTML の form 要素ではできないような複雑な リクエストの場合、 CORSプリフライトリクエスト が実行され、 リクエスト現在のURLCORSプロトコルを サポートしているかどうか確認される。

3.3.2. HTTPリクエスト

CORSリクエストとは、`Origin`ヘッダーを含むHTTPリクエストです。 ただし、CORSプロトコルに参加しているかどうかは確実には判別できません。 なぜなら、`Origin`ヘッダーは リクエストメソッドが`GET`または`HEAD`以外の時も常に含まれるためです。

CORSプリフライトリクエストは、CORSリクエストのうち、 CORSプロトコルが理解されているか確認するためのものです。 これはOPTIONSメソッドとして使い、次のヘッダーを含みます:

`Access-Control-Request-Method`

将来のCORSリクエストがそのリソースに対して使用するであろうメソッドを示す。

CORSプリフライトリクエストは、次のヘッダーも含むことがあります:

`Access-Control-Request-Headers`

将来のCORSリクエストがそのリソースに対して使用するであろうヘッダーを示す。

3.3.3. HTTPレスポンス

CORSリクエストへのHTTPレスポンスには、以下のヘッダーを含めることができます:

`Access-Control-Allow-Origin`

レスポンスが共有可能かどうかを示します。リクエストの`Origin`ヘッダーのリテラル (`null`も含む)または`*`をレスポンスで返すことができます。

`Access-Control-Allow-Credentials`

リクエスト認証情報モードが"include"の場合にレスポンスが共有可能かどうかを示します。

CORSプリフライトリクエストの場合、リクエスト認証情報モードは常に"same-origin"(認証情報は含まれない)ですが、その後のCORSリクエストではそうとは限りません。そのため、このサポートはCORSプリフライトリクエストへのHTTPレスポンスにも明示する必要があります。

CORSプリフライトリクエストへのHTTPレスポンスには、以下のヘッダーを含めることができます:

`Access-Control-Allow-Methods`

CORSプロトコルの目的で、 レスポンスURLがサポートするメソッドを示します。

`Allow`ヘッダーは、CORSプロトコルの目的には関係ありません。

`Access-Control-Allow-Headers`

CORSプロトコルの目的で、 レスポンスURLがサポートするヘッダーを示します。

`Access-Control-Max-Age`

`Access-Control-Allow-Methods`および `Access-Control-Allow-Headers`ヘッダーで提供された情報がキャッシュ可能な秒数(デフォルト5秒)を示します。

CORSプリフライトリクエストでない CORSリクエストへのHTTPレスポンスは、次のヘッダーも含めることができます:

`Access-Control-Expose-Headers`

レスポンスの一部として公開できるヘッダーを、その名前で列挙して示します。


サーバー開発者が共有の意図を持つCORSリクエストへの成功したHTTPレスポンスは、 上記のヘッダーとリクエストと一致したを含める限り、任意のステータスを利用できます。

CORSプリフライトリクエストへの成功したHTTPレスポンスも同様ですが、okステータス(例: 200や204)に制限されます。

他の種類のHTTPレスポンスは成功とは見なされず、共有されないかCORSプリフライトリクエストが失敗します。サーバーが明示的に示したい場合は、403ステータスと該当するヘッダーの省略を組み合わせて使うこともできます。

必要に応じて「failure」も共有可能ですが、それを行うと HTTP レスポンスは成功扱いになります。 そのため、CORS リクエストCORS プリフライトリクエスト でない場合の ステータス は、 403 を含めて任意の値にすることができます。

最終的に、サーバー開発者はHTTPレスポンスの扱いにおいて多くの自由があります。これらの戦略はCORSプリフライトリクエストと、その後のCORSリクエストで異なる場合があります:

3.3.4. HTTP新ヘッダー構文

CORSプロトコルで使われるヘッダーABNF

Access-Control-Request-Method    = method
Access-Control-Request-Headers   = 1#field-name

wildcard                         = "*"
Access-Control-Allow-Origin      = origin-or-null / wildcard
Access-Control-Allow-Credentials = %s"true" ; case-sensitive
Access-Control-Expose-Headers    = #field-name
Access-Control-Max-Age           = delta-seconds
Access-Control-Allow-Methods     = #method
Access-Control-Allow-Headers     = #field-name

`Access-Control-Expose-Headers`、 `Access-Control-Allow-Methods`、 `Access-Control-Allow-Headers` レスポンスヘッダーにおいては、 `*` は 認証情報なしリクエストの場合ワイルドカードとして扱われる。 そのようなリクエストでは `*` というヘッダー名メソッドだけを単独で一致させる手段は存在しない。

3.3.5. CORSプロトコルと認証情報

リクエストcredentials mode が "include" の場合、 認証情報fetch に含める以外にも CORSプロトコル の動作に影響を及ぼす。

昔は、 XMLHttpRequest を使って リクエストcredentials mode を "include" に設定できた:

var client = new XMLHttpRequest()
client.open("GET", "./")
client.withCredentials = true
/* … */

現在は fetch("./", { credentials:"include" }).then(/* … */) だけで十分である。

リクエストcredentials mode は サーバ側から必ずしも観測できるわけではない。 認証情報リクエストに存在し リクエストに含まれるときのみ観測できる。 なおCORSプリフライトリクエストでは 認証情報は絶対に含まれない。

したがってサーバ開発者は 認証情報付きのレスポンスを 共有できることにするかどうか、 および リクエストCORSプリフライトリクエストを要する場合に 認証情報が含まれてよいかを 判断する必要がある。 一般にレスポンス共有もリクエスト許可も 認証情報付きの場合かなり危険なので、 confused deputy問題 を避けるよう細心の注意を要する。

認証情報付きのレスポンスを 共有するには `Access-Control-Allow-Origin` および `Access-Control-Allow-Credentials` ヘッダー が重要である。 以下の表は https://rabbit.invalid/ へのリクエストに対し 様々な合法・非合法パターンを例示する。

リクエストの認証情報モード `Access-Control-Allow-Origin` `Access-Control-Allow-Credentials` 共有可? 備考
"omit" `*` 省略
"omit" `*` `true` credentials modeが"include"でなければ`Access-Control-Allow-Credentials`は無視される。
"omit" `https://rabbit.invalid/` 省略 直列化されたオリジンは後ろにスラッシュが付かない。
"omit" `https://rabbit.invalid` 省略
"include" `*` `true` credentials modeが"include"の場合、`Access-Control-Allow-Origin`は`*`を使えない。
"include" `https://rabbit.invalid` `true`
"include" `https://rabbit.invalid` `True` `true`は(バイト単位で)大文字小文字が区別される。

同様に、`Access-Control-Expose-Headers`、 `Access-Control-Allow-Methods`、 および `Access-Control-Allow-Headers` レスポンスヘッダーも、 リクエストcredentials mode が"include"ではない場合にのみ `*` を値として使うことができる。

3.3.6.

https://foo.invalid/のスクリプトが、https://bar.invalid/からデータを取得したいとします。(認証情報やレスポンスヘッダーアクセスは重要ではありません。)

var url = "https://bar.invalid/api?key=730d67a37d7f3d802e96396d00280768773813fbe726d116944d814422fc1a45&data=about:unicorn";
fetch(url).then(success, failure)

これはCORSプロトコルが使われますが、foo.invalid側の開発者からは完全に透過的です。CORSプロトコルの一部として、ユーザーエージェントはリクエストに`Origin`ヘッダーを含めます:

Origin: https://foo.invalid

bar.invalidからレスポンスを受信した際、ユーザーエージェントは`Access-Control-Allow-Origin`レスポンスヘッダーを検証します。その値が `https://foo.invalid` または `*` であれば、ユーザーエージェントはsuccessコールバックを呼びます。それ以外の値、または省略されている場合は、failureコールバックが呼ばれます。

foo.invalidの開発者が再び登場し、今度はbar.invalidからデータ取得時にレスポンスヘッダーも参照したいと考えています。

fetch(url).then(response => {
  var hsts = response.headers.get("strict-transport-security"),
      csp = response.headers.get("content-security-policy")
  log(hsts, csp)
})

bar.invalidは前述の例の通り、正しい`Access-Control-Allow-Origin`レスポンスヘッダーを返しています。 hstscspの値は、`Access-Control-Expose-Headers`レスポンスヘッダーに依存します。たとえば、レスポンスが次のヘッダーを含んでいた場合

Content-Security-Policy: default-src 'self'
Strict-Transport-Security: max-age=31536000; includeSubdomains; preload
Access-Control-Expose-Headers: Content-Security-Policy

このとき、hstsはnull、cspは"default-src 'self'"となります(両方のヘッダーが含まれていても)。これは、bar.invalidが各ヘッダー名を`Access-Control-Expose-Headers`レスポンスヘッダーで明示的に共有する必要があるためです。

別の方法として、bar.invalidが全てのレスポンスヘッダーを共有したい場合(認証情報を含まないリクエストに対して)、`*`を`Access-Control-Expose-Headers`レスポンスヘッダーの値として使うことができます。リクエストに認証情報が含まれる場合は、ヘッダー名を明示的に列挙する必要があり、`*`は使えません。

foo.invalidの開発者が再び登場し、今度は認証情報を含めてbar.invalidからデータを取得します。今回はCORSプロトコルが開発者から見て透過的ではありません。なぜなら、認証情報には明示的なオプトインが必要だからです:

fetch(url, { credentials:"include" }).then(success, failure)

このときbar.invalidが返す`Set-Cookie`レスポンスヘッダーも完全に機能します(そうでなければ無視されます)。

ユーザーエージェントは、リクエストに該当する認証情報を必ず含めます。またレスポンスにはより厳しい要件が課されます。bar.invalidは`Access-Control-Allow-Origin`ヘッダーの値として`https://foo.invalid`を明示する必要があり(認証情報が関与する場合`*`は不可)、`Access-Control-Allow-Credentials`ヘッダーも必要です:

Access-Control-Allow-Origin: https://foo.invalid
Access-Control-Allow-Credentials: true

これら2つのヘッダーがこの値で含まれていなければ、failureコールバックが呼ばれます。ただし、`Set-Cookie`レスポンスヘッダーは尊重されます。

3.3.7. CORSプロトコルの例外

仕様では、CORS safelist 以外の`Content-Type`ヘッダー値に対して限定的な例外が認められています。これらの例外は、ウェブコンテンツによって発生可能だが、ヘッダーやボディをウェブコンテンツからは最小限しか制御できないリクエストに対して設けられています。そのため、サーバー側は、クロスオリジンのウェブコンテンツによって以下の非プリフライトな非safelistな`Content-Type`ヘッダー値でリクエストされうることを想定する必要があります:

仕様は新たな例外の導入を避けるべきであり、慎重なセキュリティ検討の上でのみ追加するべきです。新しい例外の提案は issueの提出で行えます。

3.4. `Content-Length` ヘッダー

`Content-Length`ヘッダーは主にHTTPで定義されています。その処理モデルはHTTPで定義されたものがウェブコンテンツと互換性がないため、ここで定義されています。[HTTP]

長さを抽出するには、 ヘッダーリスト headersを与えて次の手順を実行する:

  1. valuesを、headersから`Content-Length`を取得・デコード・分割した結果とする。

  2. valuesがnullならnullを返す。

  3. candidateValueをnullとする。

  4. valuesvalue について:

    1. candidateValueがnullなら、candidateValuevalueを設定する。

    2. そうでなければ、valuecandidateValueと異なれば、failureを返す。

  5. candidateValueが空文字列か、コードポイントASCII数字でないものが含まれていれば、nullを返す。

  6. candidateValueを10進数として解釈して返す。

3.5. `Content-Type` ヘッダー

`Content-Type`ヘッダーは主にHTTPで定義されています。その処理モデルはHTTPで定義されたものがウェブコンテンツと互換性がないため、ここで定義されています。[HTTP]

MIMEタイプを抽出するには、 ヘッダーリスト headersを与えて次の手順を実行する。これらはfailureまたはMIMEタイプを返す。

  1. charsetをnullとする。

  2. essenceをnullとする。

  3. mimeTypeをnullとする。

  4. valuesを、headersから`Content-Type`を取得・デコード・分割した結果とする。

  5. valuesがnullならfailureを返す。

  6. valuesvalue について:

    1. temporaryMimeTypevalueMIMEタイプとして構文解析した結果とする。

    2. temporaryMimeTypeがfailure、またはそのエッセンスが"*/*"なら、continue

    3. mimeTypetemporaryMimeTypeを設定する。

    4. mimeTypeエッセンスessenceと異なる場合:

      1. charsetをnullに設定する。

      2. mimeTypeparameters["charset"]が存在すれば、charsetにその値を設定する。

      3. essencemimeTypeエッセンスを設定する。

    5. そうでなければ、mimeTypeparameters["charset"]が存在せず、かつcharsetがnullでなければ、mimeTypeparameters["charset"]にcharsetを設定する。

  7. mimeTypeがnullならfailureを返す。

  8. mimeTypeを返す。

MIMEタイプを抽出するがfailureを返した場合や、MIMEタイプエッセンスが与えられたフォーマットに不適切な場合は、致命的エラーとして扱うこと。既存のウェブプラットフォーム機能はこのパターンに従っていないことが多く、長年にわたりセキュリティ脆弱性の主な原因となっています。一方で、MIMEタイプパラメータは通常無視しても安全です。

MIMEタイプを抽出するの実際の動作例:

Headers(ネットワーク上の値) 出力(直列化
Content-Type: text/plain;charset=gbk, text/html
text/html
Content-Type: text/html;charset=gbk;a=b, text/html;x=y
text/html;x=y;charset=gbk
Content-Type: text/html;charset=gbk;a=b
Content-Type: text/html;x=y
Content-Type: text/html;charset=gbk
Content-Type: x/x
Content-Type: text/html;x=y
text/html;x=y
Content-Type: text/html
Content-Type: cannot-parse
text/html
Content-Type: text/html
Content-Type: */*
Content-Type: text/html
Content-Type:

レガシーエンコーディング抽出は、failureまたはMIMEタイプ mimeTypeエンコーディング fallbackEncodingを与えて次の手順を実行する:

  1. mimeTypeがfailureならfallbackEncodingを返す。

  2. mimeType["charset"]が存在しなければ、fallbackEncodingを返す。

  3. tentativeEncodingmimeType["charset"]からエンコーディング取得した結果とする。

  4. tentativeEncodingがfailureならfallbackEncodingを返す。

  5. tentativeEncodingを返す。

このアルゴリズムはmimeTypeがfailureでも受け付けるため、MIMEタイプを抽出すると容易に組み合わせられます。

これが"legacy"とされるのは、現代のフォーマットはUTF-8のみ使うことが推奨されているためです。

3.6. `X-Content-Type-Options` ヘッダー

X-Content-Type-Options」 レスポンスヘッダーは、 レスポンスの `Content-Type`ヘッダーリクエスト の送信先と照合することを要求できる。

ヘッダーリスト list を与え、 nosniffを判定する には次の手順を行う:

  1. values取得・デコード・分割 (`X-Content-Type-Options`, list) の結果とする。

  2. values が null なら false を返す。

  3. values[0] が ASCII大文字小文字無視 で "nosniff" と一致するなら true を返す。

  4. false を返す。

ウェブ開発者および適合性チェッカーは、 `X-Content-Type-Options` について値ABNFを次に従う必要がある:

X-Content-Type-Options           = "nosniff" ; case-insensitive

3.6.1. responserequest で nosniff のためブロックするべきか?

次の手順を行う:

  1. nosniffを判定する (responseヘッダーリスト) が false なら allowed を返す。

  2. mimeTypeMIME Type抽出 (responseヘッダーリスト) の結果とする。

  3. destinationrequest送信先 とする。

  4. destinationスクリプト系 で、 mimeType が失敗 または JavaScript MIME type でなければ blocked を返す。

  5. destination が "style" で、 mimeType が失敗 または その エッセンス が "text/css" でなければ blocked を返す。

  6. allowed を返す。

リクエスト送信先のうち スクリプト系 または "style" のときのみ考慮される。 悪用問題が想定されるのはこれらのみ。また "image" は実環境の内容と相性が悪かったため対象外。

3.7. `Cross-Origin-Resource-Policy` ヘッダー

Cross-Origin-Resource-Policy」 レスポンスヘッダーは、 リクエスト現在のURLオリジン を、リクエストoriginと比較するよう要求できる。これは、 リクエストmodeが "no-cors"のときに用いることができる。

その ABNF:

Cross-Origin-Resource-Policy     = %s"same-origin" / %s"same-site" / %s"cross-origin" ; case-sensitive

Cross-Origin Resource Policy チェック を行うには、 オリジン origin環境設定オブジェクト settingsObject、 文字列 destinationレスポンス response、 オプションで真偽値 forNavigation を与え以下の手順を行う:

  1. forNavigation が与えられていなければ、false に設定する。

  2. embedderPolicysettingsObjectポリシーコンテナエンベッダーポリシーとする。

  3. コーポリシー内部チェックorigin、 "unsafe-none"、 responseforNavigation で実行し blocked を返したら blocked を返す。

    このステップはCross-Origin Embedder Policyに関連しない違反は以下で報告しないために必要。

  4. コーポリシー内部チェックoriginembedderPolicyreport only valueresponseforNavigation で行い、 blocked なら CORP違反レポートをキュー ( responsesettingsObjectdestination、true ) を行う。

  5. コーポリシー内部チェックoriginembedderPolicyvalueresponseforNavigation で行い allowed なら allowed を返す。

  6. CORP違反レポートをキュー ( responsesettingsObjectdestination、false ) を実施。

  7. blocked を返す。

HTMLの navigateアルゴリズムだけがforNavigationをtrueにして使用するがこれは常に入れ子のナビゲーションのみ。 それ以外では responseinternal responseまたは opaque filtered response の internal response となる。[HTML]

Cross-Origin Resource Policy 内部チェック を行うには オリジン originエンベッダーポリシー値 embedderPolicyValueレスポンス response、 真偽値 forNavigation を与え以下の手順を行う:

  1. forNavigation が true で embedderPolicyValue が "unsafe-none" なら allowed を返す。

  2. policy取得 (`Cross-Origin-Resource-Policy`, responseヘッダーリスト) の結果とする。

    たとえば `Cross-Origin-Resource-Policy: same-site, same-origin` と書いても、embedderPolicyValueが"unsafe-none" であれば、下記ロジックに引っかからない限りallowedとなる。 2つ以上のCORPヘッダーを書いても同じ挙動。

  3. policy が `same-origin`, `same-site`, `cross-origin` の いずれでもなければ、policy を null にする。

  4. policy が null なら、embedderPolicyValueに応じて:

    "unsafe-none"

    何もしない。

    "credentialless"

    以下のいずれかなら policy を `same-origin` に設定する:

    "require-corp"

    policy を `same-origin` に設定

  5. policyによりswitch:

    null
    `cross-origin`

    allowed を返す。

    `same-origin`

    もし originresponseURLorigin同一オリジン なら allowed を返す。

    それ以外は blocked を返す。

    `same-site`

    以下すべてが満たされるなら

    なら allowed を返す。

    そうでなければblocked を返す。

    `Cross-Origin-Resource-Policy: same-site`は安全なトランスポートで配信されたレスポンスは 非安全なリクエスト元オリジンとは一致しないことに注意。 同じホストであっても安全に運ばれたレスポンスは同じく安全な発信元のみ一致する。

Cross-Origin Embedder Policy CORP違反レポートをキューする には、 レスポンス response環境設定オブジェクト settingsObject、 文字列 destination、真偽値 reportOnly を与え以下の手順を行う:

  1. endpointsettingsObjectポリシーコンテナエンベッダーポリシー report only reporting endpoint、 ただし reportOnly が true の場合であり、 false の場合は ポリシーコンテナエンベッダーポリシー reporting endpoint

  2. serializedURL 報告用レスポンスURL直列化(response) の結果とする。

  3. dispositionreportOnly がtrueなら "reporting"、そうでなければ "enforce" にする。

  4. body を、次のプロパティを含む新しいオブジェクトとする:

    key value
    "type" "corp"
    "blockedURL" serializedURL
    "destination" destination
    "disposition" disposition
  5. レポートを生成しキュー ( settingsObjectグローバルオブジェクト"coep" report typeendpointbody) を呼び出す。[REPORTING]

3.8. `Sec-Purpose` ヘッダー

`Sec-Purpose` HTTPリクエストヘッダーは、そのリクエストがユーザーによる即時利用以外の目的でリソースを要求していることを示します。

`Sec-Purpose` ヘッダーフィールドはstructured headerであり、その値はトークンでなければなりません。

定義されているトークンprefetchのみです。これはリクエストの目的が、近いうちに必要になると予想されるリソースを取得することであることを示します。

サーバーはこれを利用して、プリフェッチ用のキャッシュ有効期限を調整したり、プリフェッチを拒否したり、ページ訪問回数のカウント時に別扱いすることができます。

4. フェッチング

以下のアルゴリズムは fetching を定義します。大まかに言えば、これは request と、 操作の各段階で実行される一つ以上のアルゴリズムを受け取ります。 response は下に列挙された 最後の二つのアルゴリズムに渡されます。最初の二つのアルゴリズムはアップロードを扱うために使うことができます。

To fetch, given a request request, an optional algorithm processRequestBodyChunkLength, an optional algorithm processRequestEndOfBody, an optional algorithm processEarlyHintsResponse, an optional algorithm processResponse, an optional algorithm processResponseEndOfBody, an optional algorithm processResponseConsumeBody, and an optional boolean useParallelQueue (default false), run the steps below. If given, processRequestBodyChunkLength must be an algorithm accepting an integer representing the number of bytes transmitted. If given, processRequestEndOfBody must be an algorithm accepting no arguments. If given, processEarlyHintsResponse must be an algorithm accepting a response. If given, processResponse must be an algorithm accepting a response. If given, processResponseEndOfBody must be an algorithm accepting a response. If given, processResponseConsumeBody must be an algorithm accepting a response and null, failure, or a byte sequence

ユーザーエージェントは進行中のフェッチを suspend するよう要求されることがあります。 ユーザーエージェントはその一時停止要求を受け入れるか無視するか選択できます。 一時停止されたフェッチは resumed できます。 進行中のフェッチが当該リクエストの HTTP キャッシュ内のレスポンスを 更新している場合、ユーザーエージェントは一時停止要求を無視すべきです。

リクエストのキャッシュモードが "no-store"、またはレスポンスに `Cache-Control: no-store` ヘッダーが含まれる場合、ユーザーエージェントはこのリクエストに 関するHTTPキャッシュのエントリを更新しません。[HTTP-CACHING]

  1. Assert: requestmode が "navigate" であるか、processEarlyHintsResponse が null であること。

    early hints(ステータスが 103 の responses)の処理はナビゲーションに対してのみ精査されます。

  2. taskDestination を null にする。

  3. crossOriginIsolatedCapability を false にする。

  4. Populate request from client を与えられた request に対して実行する。

  5. もし requestclient が null でないならば:

    1. taskDestinationrequestclientglobal object に設定する。

    2. crossOriginIsolatedCapabilityrequestclientcross-origin isolated capability に設定する。

  6. もし useParallelQueue が true なら、taskDestinationstarting a new parallel queue の結果に設定する。

  7. timingInfo を新しい fetch timing info として定め、その start timepost-redirect start timecoarsened shared current timecrossOriginIsolatedCapability を与えた場合)にし、 render-blockingrequestrender-blocking に設定する。

  8. fetchParams を新しい fetch params として定め、その requestrequesttiming infotimingInfoprocess request body chunk lengthprocessRequestBodyChunkLengthprocess request end-of-bodyprocessRequestEndOfBodyprocess early hints responseprocessEarlyHintsResponseprocess responseprocessResponseprocess response consume bodyprocessResponseConsumeBodyprocess response end-of-bodyprocessResponseEndOfBodytask destinationtaskDestination、および cross-origin isolated capabilitycrossOriginIsolatedCapability であるようにする。

  9. もし requestbodybyte sequence であるなら、requestbodyrequestbodyas a body に設定する。

  10. もし 次のすべての条件が真であるなら:

    ならば:

    1. Assert: requestoriginsame origin であり、 requestclientorigin と同じであること。

    2. onPreloadedResponseAvailable を、次の手順を与えられた response response に対して実行するアルゴリズムとして定める:fetchParamspreloaded response candidateresponse に設定する。

    3. foundPreloadedResource を、consume a preloaded resourcerequestclient に対して呼び出した結果として求める。呼び出しには requestURLrequestdestinationrequestmoderequestcredentials moderequestintegrity metadata、 および onPreloadedResponseAvailable を与える。

    4. もし foundPreloadedResource が true で、かつ fetchParamspreloaded response candidate が null であるなら、fetchParamspreloaded response candidate を "pending" に設定する。

  11. もし requestheader list が `Accept` を 含んでいない なら:

    1. value を `*/*` にする。

    2. もし requestinitiator が "prefetch" なら、 valuedocument `Accept` header value に設定する。

    3. それ以外の場合、ユーザーエージェントは次の一致する最初の文を使って requestdestination に応じて value を設定すべきです(該当するものがあれば):

      "document"
      "frame"
      "iframe"
      document `Accept` header value
      "image"
      `image/png,image/svg+xml,image/*;q=0.8,*/*;q=0.5`
      "json"
      `application/json,*/*;q=0.5`
      "style"
      `text/css,*/*;q=0.1`
    4. Append (`Accept`, value) を requestheader list に追加する。

  12. もし requestheader list が `Accept-Language` を 含んでおらず かつ requestclient が null でない場合:

    1. emulatedLanguageWebDriver BiDi emulated language として求める(requestclient に対する)。

    2. もし emulatedLanguage が null でないなら:

      1. 次に、encodedEmulatedLanguageemulatedLanguage とし、 同型にエンコードされた.

      2. Append (`Accept-Language`, encodedEmulatedLanguage) を requestheader list に追加する。

  13. もし requestheader list が `Accept-Language` を 含んでいない なら、ユーザーエージェントは append (`Accept-Language, 適切な header value)を requestheader list に追加すべきです。

  14. もし requestinternal priority が null であるなら、 requestpriorityinitiatordestination、および render-blockingimplementation-defined な方法で用いて、 requestinternal priorityimplementation-defined なオブジェクトに設定する。

    その implementation-defined オブジェクトは、 HTTP/2 用のストリームの重みや依存、適用されるトランスポート(HTTP/3 を含む)で用いられる Extensible Prioritization Scheme for HTTP の優先度、または HTTP/1 フェッチの 発行と処理の優先度付けに使われる同等の情報を包含する可能性があります。 [RFC9218]

  15. もし requestsubresource request であるなら:

    1. record を新しい fetch record として定め、その requestrequest であり、かつ controllerfetchParamscontroller であるようにする。

    2. Append recordrequestclientfetch groupfetch records に追加する。

  16. main fetchfetchParams に対して実行する。

  17. fetchParamscontroller を返す。

To populate request from client given a request request:

  1. もし requesttraversable for user prompts が "client" なら:

    1. requesttraversable for user prompts を "no-traversable" に設定する。

    2. もし requestclient が null でないなら:

      1. globalrequestclientglobal object に設定する。

      2. もし globalWindow オブジェクトであり、かつ globalnavigable が null でないなら、 requesttraversable for user promptsglobalnavigabletraversable navigable に設定する。

  2. もし requestorigin が "client" であるなら:

    1. Assert: requestclient は null でないこと。

    2. requestoriginrequestclientorigin に設定する。

  3. もし requestpolicy container が "client" であるなら:

    1. もし requestclient が null でないなら、 requestpolicy containerclone によって requestclientpolicy container から作成されたものに設定する。 [HTML]

    2. それ以外の場合、requestpolicy container を新しい policy container に設定する。

4.1. メインフェッチ

メインフェッチするには、フェッチパラメータfetchParamsとオプションのブール値recursive(デフォルトはfalse)を指定して、以下の手順を実行します:

  1. requestfetchParamsrequestを設定する。

  2. responseをnullとする。

  3. requestlocal-URLs-only flagがセットされていて、かつrequestcurrent URLローカルでなければ、responseネットワークエラーを設定する。

  4. Content Security Policy違反をrequestに対して報告する。

  5. 必要に応じてrequestを信頼できるURLにアップグレードする。

  6. 必要に応じて混在コンテンツrequestを信頼できるURLにアップグレードする。

  7. 悪いポートのためrequestをブロックすべきか混在コンテンツとしてrequestのフェッチをブロックすべきかContent Security Policyによりrequestをブロックすべきか整合性ポリシーによりrequestをブロックすべきかblockedを返した場合、responseネットワークエラーを設定する。

  8. requestreferrer policyが空文字列であれば、requestreferrer policyrequestpolicy containerreferrer policyに設定する。

  9. requestreferrerが"no-referrer"でなければ、requestreferrerリクエストのreferrerを決定するの結果に設定する。[REFERRER]

    Referrer Policyに記載されている通り、ユーザーエージェントはエンドユーザーに"no-referrer"に上書きする、またはより機微な情報のみを公開するオプションを提供できます。

  10. 以下すべての条件を満たす場合、requestcurrent URLschemeを"https"に設定する:

    すべてのDNS操作は通常実装定義であるため、DNS解決にHTTPS RRが含まれているかどうかの判定も実装定義です。DNS操作は伝統的にコネクション取得の試行まで行われないため、ユーザーエージェントはDNS操作を早期に実施したり、ローカルDNSキャッシュを参照したり、フェッチアルゴリズムの後段で判明した場合に論理を巻き戻す必要があるかもしれません。

  11. recursiveがfalseであれば、残りの手順を並列で実行する。

  12. responseがnullであれば、最初に一致する条件の手順を実行してresponseを設定する:

    fetchParamspreloaded response candidateがnullでない
    1. fetchParamspreloaded response candidateが"pending"でなくなるまで待つ。

    2. アサートfetchParamspreloaded response candidateレスポンスである。

    3. fetchParamspreloaded response candidateを返す。

    requestcurrent URLoriginrequestorigin同一オリジンで、かつrequestresponse taintingが"basic"である
    requestcurrent URLschemeが"data"である
    requestmode が "navigate"、"websocket" または "webtransport" の場合
    1. requestresponse taintingを"basic"に設定する。

    2. scheme-fetch」と fetchParams を指定して、override fetch を実行した結果を返す。

    HTMLは、URLスキーム が "data" の場合、 そこから作成されるドキュメントおよびワーカーに一意な 不透明オリジン を割り当てます。Service Worker は URLスキームHTTP(S) スキーム である場合のみ作成できます。 [HTML] [SW]

    requestmodeが"same-origin"である

    ネットワークエラーを返す。

    requestmodeが"no-cors"である
    1. requestredirect modeが"follow"でなければネットワークエラーを返す。

    2. requestresponse taintingを"opaque"に設定する。

    3. scheme-fetch」と fetchParams を指定して、override fetch を実行した結果を返す。

    requestcurrent URLschemeHTTP(S)スキームでない

    ネットワークエラーを返す。

    requestuse-CORS-preflight flagがセットされている
    requestunsafe-request flagがセットされていて、かつrequestmethodCORS安全リストメソッドでない、またはCORS安全でないリクエストヘッダー名requestheader list空でない
    1. requestresponse taintingを"cors"に設定する。

    2. corsWithPreflightResponse を、「http-fetch」、fetchParams、および true を指定して override fetch を実行した結果とする。

    3. corsWithPreflightResponseネットワークエラーであれば、キャッシュエントリをクリアrequestで実行する。

    4. corsWithPreflightResponseを返す。

    その他
    1. requestresponse taintingを"cors"に設定する。

    2. http-fetch」と fetchParams を指定して、override fetch を実行した結果を返す。

  13. recursiveがtrueであれば、responseを返す。

  14. responseネットワークエラーでなく、かつresponseフィルタ済みレスポンスでなければ、以下を実行する:

    1. requestresponse taintingが"cors"であれば、以下を実行する:

      1. headerNamesヘッダーリスト値の抽出を`Access-Control-Expose-Headers`とresponseheader listで実行した結果を設定する。

      2. requestcredentials modeが"include"でなく、かつheaderNamesが`*`を含んでいれば、responseCORS公開ヘッダー名リストresponseheader listに含まれるすべての一意なヘッダーを設定する。

      3. それ以外でheaderNamesがnullまたは失敗でなければ、responseCORS公開ヘッダー名リストheaderNamesを設定する。

        headerNamesのうち1つは`*`である場合がありますが、この時点ではヘッダーが`*`の場合のみ一致します。

    2. 以下に応じてresponseresponse内部レスポンスとするフィルタ済みレスポンスに設定する:

      "basic"
      基本フィルタ済みレスポンス
      "cors"
      CORSフィルタ済みレスポンス
      "opaque"
      不透明フィルタ済みレスポンス
  15. internalResponseresponseを設定する。ただしresponseネットワークエラーならresponse、それ以外ならresponse内部レスポンスを設定する。

  16. internalResponseURLリストであれば、requestURLリスト複製を設定する。

    レスポンスURLリストは空の場合があり、例えばabout:URLのフェッチ時などです。

  17. internalResponseリダイレクト汚染requestredirect-taintを設定する。

  18. requesttiming allow failed flagが未設定なら、internalResponsetiming allow passed flagを設定する。

  19. responseネットワークエラーでなく、かつ下記のどれかがblockedを返す場合

    この場合responseinternalResponseネットワークエラーに設定する。

  20. responsetype が "opaque" であり、 internalResponsestatusレンジステータス で、 internalResponserange-requested フラグ が設定されており、かつ requestヘッダーリスト に `Range` が 含まれていない 場合、 response および internalResponseネットワークエラー に設定する。

    従来、API はレンジが要求されていない場合でもレンジレスポンスを受け入れてきました。 これは、以前のレンジ要求による部分レスポンスや、レンジ不成立レスポンスが、 レンジ要求を行っていない API に提供されるのを防ぐためです。

    詳細

    上記の手順は、次の攻撃を防止します。

    メディア要素を用いて、クロスオリジンの HTML リソースの一部範囲を要求します。 これは無効なメディアであるにもかかわらず、レスポンスのクローンへの参照を Service Worker 内に保持できます。 これを後で script 要素の fetch に対するレスポンスとして使用できます。 部分レスポンスが(リソース全体はそうでなくても)有効な JavaScript である場合、 それを実行することで機密データが漏えいしてしまいます。

  21. responseネットワークエラーでなく、かつrequestmethodが`HEAD`または`CONNECT`である、またはinternalResponsestatusnullボディステータスであれば、internalResponsebodyをnullに設定し、以降のエンキューは無視する。

    この処理はHTTP違反サーバへのエラー処理の標準化です。

  22. requestintegrity metadataが空文字列でなければ、以下を実行する:

    1. processBodyErrorにこの手順:fetch response handoverfetchParamsネットワークエラーで実行する。

    2. responsebodyがnullならprocessBodyErrorを実行し、以降の手順を中止する。

    3. processBodybytesを受け取った場合の手順を設定する:

      1. bytes一致しない場合、requestintegrity metadataに、processBodyErrorを実行し以降の手順を中止する。[SRI]

      2. responsebodybytesボディとしてを設定する。

      3. fetch response handoverfetchParamsresponseで実行する。

    4. 完全に読み取るresponsebodyに対してprocessBodyprocessBodyErrorで実行する。

  23. それ以外の場合、fetch response handoverfetchParamsresponseで実行する。


フェッチレスポンス引き渡しは、フェッチパラメータfetchParamsレスポンスresponseを指定して、以下の手順を実行します:

  1. timingInfofetchParamsタイミング情報を設定する。

  2. responseネットワークエラーでなく、かつfetchParamsrequestclientセキュアコンテキストなら、timingInfoserver-timing headersresponse内部レスポンスヘッダーリストから`Server-Timing`を取得・デコード・分割した結果を設定する。

    response内部レスポンスを用いるのは安全です。`Server-Timing`ヘッダー情報の公開は`Timing-Allow-Origin`ヘッダーによって制御されます。

    ユーザーエージェントは非セキュアコンテキストのリクエストにも`Server-Timing`ヘッダーを公開する場合があります。

  3. fetchParamsrequestdestinationが"document"であれば、fetchParamscontrollerfull timing infofetchParamsタイミング情報を設定する。

  4. processResponseEndOfBodyに以下の手順を設定する:

    1. unsafeEndTimeunsafe shared current timeを設定する。

    2. fetchParamscontrollerreport timing stepsに、グローバルオブジェクトglobalを受け取る手順として以下を設定する:

      1. fetchParamsrequestURLschemeHTTP(S)スキームでなければreturnする。

      2. timingInfoend timerelative high resolution timeunsafeEndTime, globalを指定)で設定する。

      3. cacheStateresponsecache stateを設定する。

      4. bodyInforesponsebody infoを設定する。

      5. responsetiming allow passed flagが未設定なら、timingInfo不透明タイミング情報の作成timingInfoを指定)の結果を設定し、cacheStateを空文字列に設定する。

        これはresponseネットワークエラーの場合を含みます。

      6. responseStatusを0に設定する。

      7. fetchParamsrequestmodeが"navigate"でない、またはresponseredirect taintが"same-origin"であれば:

        1. responseStatusresponsestatusを設定する。

        2. mimeTypeMIMEタイプの抽出responseheader listを指定)の結果を設定する。

        3. mimeTypeが失敗でなければ、bodyInfocontent typeサポートされているMIMEタイプの最小化mimeType)の結果を設定する。

      8. fetchParamsrequestinitiator typeがnullでなければ、mark resource timingtimingInfo, fetchParamsrequestURL, fetchParamsrequestinitiator type, global, cacheState, bodyInfo, responseStatus)を実行する。

    3. processResponseEndOfBodyTaskに以下の手順を設定する:

      1. fetchParamsrequestdone flagを設定する。

      2. fetchParamsprocess response end-of-bodyがnullでなければ、fetchParamsprocess response end-of-bodyresponse)を実行する。

      3. fetchParamsrequestinitiator typeがnullでなく、かつfetchParamsrequestclientグローバルオブジェクトfetchParamstask destinationであれば、fetchParamscontrollerreport timing stepsfetchParamsrequestclientグローバルオブジェクト)を実行する。

    4. フェッチタスクをキューし、processResponseEndOfBodyTaskfetchParamstask destinationで実行する。

  5. fetchParamsprocess responseがnullでなければ、フェッチタスクをキューし、fetchParamsprocess responseresponse)をfetchParamstask destinationで実行する。

  6. internalResponseresponseを設定する。ただしresponseネットワークエラーならresponse、それ以外ならresponse内部レスポンスを設定する。

  7. internalResponsebodyがnullなら、processResponseEndOfBodyを実行する。

  8. それ以外の場合:

    1. transformStreamに新しいTransformStreamを設定する。

    2. identityTransformAlgorithmに、chunkを受け取ったときtransformStreamchunkenqueueするアルゴリズムを設定する。

    3. transformStreamのセットアップを行い、transformAlgorithmidentityTransformAlgorithmに、flushAlgorithmprocessResponseEndOfBodyに設定する。

    4. internalResponsebodystreamに、internalResponsebodystreampipe throughした結果をtransformStreamで設定する。

    このTransformStreamは、ストリームの終端到達時の通知目的で必要です。それ以外は恒等変換ストリームです。

  9. fetchParamsprocess response consume bodyがnullでなければ、以下を実行する:

    1. processBodynullOrBytesを受け取ったときfetchParamsprocess response consume bodyresponse, nullOrBytes)を実行する手順を設定する。

    2. processBodyErrorfetchParamsprocess response consume bodyresponse, failure)を実行する手順を設定する。

    3. internalResponsebodyがnullなら、フェッチタスクをキューし、processBody(null)をfetchParamstask destinationで実行する。

    4. それ以外の場合、完全に読み取るinternalResponsebodyに対してprocessBody, processBodyError, fetchParamstask destinationで実行する。

4.2. オーバーライドフェッチ

オーバーライドフェッチは、「scheme-fetch」または「http-fetch」の typefetch params fetchParams、さらにオプションの boolean makeCORSPreflight(デフォルトは false)を受け取る:

  1. requestfetchParamsrequest とする。

  2. responserequest に対して 要求のオーバーライド可能なレスポンス を実行した結果とする。

  3. response が null でなければ、response を返す。

  4. type に応じて以下を実行する:

    "scheme fetch"

    responseスキームフェッチfetchParams で実行した結果とする。

    "HTTP fetch"

    responseHTTPフェッチfetchParamsmakeCORSPreflight で実行した結果とする。

  5. response を返す。

この リクエストの応答を潜在的に上書きする アルゴリズムは リクエスト request を受け取り、レスポンス または null を返します。 その動作は 実装定義 であり、ユーザーエージェントが リクエスト に対して 応答を直接返して介入すること、あるいは null を返してリクエストを進行させることを可能にします。

デフォルトでは、アルゴリズムは以下の簡易的な実装となる:

  1. null を返す。

ユーザーエージェントは一般的に、このデフォルト実装をより複雑な動作で上書きする。例えば、ユーザーエージェントは利用者の安全を守るために「https://unsafe.example/」へのリクエストを一般的にブロックしつつ、広く利用されている「https://unsafe.example/widget.js」向けのリソースには互換性を保つためのシムを合成するかもしれない。その実装例は次のようになる:

  1. requestcurrent urlhost登録可能ドメイン が「unsafe.example」の場合:

    1. requestcurrent urlpath が « "widget.js" » の場合:

      1. body を[ここにシムされた内容のバイト列を挿入する]とする。

      2. 次のプロパティを持つ新しい response を返す:

        type
        "cors"
        status
        200
        ...
        ...
        body
        body本文として取得した結果。
    2. ネットワークエラー を返す。

  2. null を返す。

4.3. スキームフェッチ

スキームフェッチは、fetch params fetchParams を受け取る:

  1. fetchParamsキャンセル済みの場合、fetchParamsに対して 適切なネットワークエラー を返す。

  2. requestfetchParamsrequest とする。

  3. requestcurrent URLscheme に応じて以下の手順を実行する:

    "about"

    requestcurrent URLpath が "blank" の場合、response を新規作成し、 status message を `OK`、 header list を « (`Content-Type`, `text/html;charset=utf-8`) »、 body を空のバイト列 本文として設定して返す。

    URL(例:"about:config")は ナビゲーション時に処理され、 fetchの文脈では ネットワークエラー となる。

    "blob"
    1. blobURLEntry を、requestcurrent URLblob URL entry とする。

    2. もし requestmethod が `GET` でない、または blobURLEntry が null であるなら、network error を返す。 [FILEAPI]

      `GET` method の制約は、相互運用性以外に有用な目的を持たない。

    3. requestEnvironment を、request を与えて 環境を決定した結果とする。

    4. isTopLevelSelfFetch を false とする。

    5. もし requestclient が non-null なら:

      1. global を、requestclientglobal object とする。

      2. 次の条件がすべて真なら:

        その場合、isTopLevelSelfFetch を true に設定する。

    6. stringOrEnvironment を次の手順の結果とする:

      1. もし requestdestination が "document" なら、 "top-level-navigation" を返す。

      2. もし isTopLevelSelfFetch が true なら、 "top-level-self-fetch" を返す。

      3. requestEnvironment を返す。

    7. blob を、blobURLEntrystringOrEnvironment を与えて blob オブジェクトを取得した結果とする。

    8. もし blobBlob オブジェクトでないなら、network error を返す。

    9. response を新しい response とする。

    10. fullLengthblobsize とする。

    11. serializedFullLength を、fullLengthserialized および isomorphic encoded したものとする。

    12. typeblobtype とする。

    13. もし requestheader list含まない 場合、 `Range` を:

      1. bodyWithType を、安全に抽出して得た blob の結果とする。

      2. responsestatus message を `OK` に設定する。

      3. responsebody を、 bodyWithTypebody に設定する。

      4. responseheader list を « (`Content-Length`, serializedFullLength), (`Content-Type`, type) » に設定する。

    14. それ以外の場合:

      1. responserange-requested flag を設定する。

      2. rangeHeader を、取得した結果、すなわち requestheader list からの `Range` とする。

      3. rangeValue を、単一の Range ヘッダー値を解析 した結果とし、rangeHeader と true を与える。

      4. もし rangeValue が failure なら、network error を返す。

      5. (rangeStart, rangeEnd) を rangeValue とする。

      6. もし rangeStart が null なら:

        1. rangeStartfullLengthrangeEnd に設定する。

        2. rangeEndrangeStart + rangeEnd − 1 に設定する。

      7. それ以外の場合:

        1. もし rangeStartfullLength 以上なら、 network error を返す。

        2. もし rangeEnd が null、または rangeEndfullLength 以上なら、rangeEndfullLength − 1 に設定する。

      8. slicedBlob を、slice blob を呼び出した結果とし、 blob, rangeStart, rangeEnd + 1, および type を与える。

        Range ヘッダーは包含的なバイト範囲を表す一方で、slice blob アルゴリズムの入力範囲はそうではない。slice blob アルゴリズムを使用するためには、 rangeEnd をインクリメントする必要がある。

      9. slicedBodyWithType を、 安全に抽出した slicedBlob の結果とする。

      10. responsebody を、 slicedBodyWithTypebody に設定する。

      11. serializedSlicedLength を、slicedBlobsizeserialized および isomorphic encoded したものとする。

      12. contentRange を、content range を構築した結果とし、 rangeStart, rangeEnd, および fullLength を与える。

      13. responsestatus を 206 に設定する。

      14. responsestatus message を `Partial Content` に設定する。

      15. responseheader list を « (`Content-Length`, serializedSlicedLength), (`Content-Type`, type), (`Content-Range`, contentRange) » に設定する。

    15. response を返す。

    "data"
    1. dataURLStruct を、requestdata: URL プロセッサcurrent URL に対して実行した結果とする。

    2. もし dataURLStruct が failure なら、network error を返す。

    3. mimeType を、dataURLStructMIME type直列化したものとする。

    4. 新しい response を返す。その status message は `OK`、header list は « (`Content-Type`, mimeType) »、そして bodydataURLStructbody本文として 用いたものである。

    "file"

    現時点では不本意ながら、file: URL は読者への演習問題として残されている。

    判断に迷う場合は、network error を返すこと。

    HTTP(S) スキーム

    fetchParams を与えて HTTP fetch を実行した結果を返す。

  4. network error を返す。

環境を決定するためには、request request を受け取る:

  1. requestreserved client が null でなければ、 requestreserved client を返す。

  2. requestclient が null でなければ、 requestclient を返す。

  3. null を返す。

4.4. HTTPフェッチ

HTTPフェッチは、 fetch params fetchParams と、オプションの boolean makeCORSPreflight(デフォルトは false)を受け取り、以下の手順を実行する:

  1. requestfetchParamsrequest とする。

  2. responseinternalResponse を null とする。

  3. requestservice-workers mode が "all" の場合:

    1. requestForServiceWorkerclonerequest を複製したものとする。

    2. requestForServiceWorkerbody が null でなければ:

      1. transformStream を新しい TransformStream とする。

      2. transformAlgorithmchunk を受け取るアルゴリズムとして以下とする:

        1. fetchParamsキャンセル済みなら、これらの手順を中止する。

        2. chunkUint8Array オブジェクトでなければ、 terminatefetchParamscontroller を終了する。

        3. それ以外の場合、enqueuechunktransformStream に追加する。ユーザーエージェントは、チャンクを 実装定義の適切なサイズに分割して enqueue してもよいし、チャンク群を 実装定義の適切なサイズに連結して enqueue してもよい。

      3. transformStreamtransformAlgorithm にセットアップする。

      4. requestForServiceWorkerbodystreamrequestForServiceWorkerbodystreampipe through transformStream した結果に設定する。

    3. serviceWorkerStartTimecoarsened shared current timefetchParamscross-origin isolated capability で実行した結果とする。

    4. fetchResponsehandle fetchrequestForServiceWorkerfetchParamscontroller および fetchParamscross-origin isolated capability とともに渡して呼び出した結果とする。 [HTML] [SW]

    5. もし fetchResponseresponse の場合:

      1. responsefetchResponse を設定する。

      2. fetchParamstiming infofinal service worker start timeserviceWorkerStartTime を設定する。

      3. fetchParamstiming infoservice worker timing inforesponseservice worker timing info を設定する。

      4. もし requestbody が null でない場合、 cancelrequestbody に undefined で適用する。

      5. internalResponseresponse に設定する。ただし、responsefiltered response であれば、 responseinternal response に設定する。

      6. 次のいずれか真の場合

        • responsetype が "error" である

        • requestmode が "same-origin" で、かつ responsetype が "cors" である

        • requestmode が "no-cors" でなく、かつ responsetype が "opaque" である

        • requestredirect mode が "manual" でなく、かつ responsetype が "opaqueredirect" である
        • requestredirect mode が "follow" でなく、かつ responseURL list が 2 つ以上の項目を持つ場合

        その場合、network error を返す。

    6. それ以外の場合、fetchResponseservice worker timing info であれば、 fetchParamstiming infoservice worker timing infofetchResponse を設定する。

  4. response が null の場合:

    1. makeCORSPreflight が true かつ以下のいずれかが真の場合:

      この場合:

      1. preflightResponseCORSプリフライトフェッチrequest で実行した結果とする。

      2. preflightResponseネットワークエラーの場合、 preflightResponse を返す。

      この手順は CORSプリフライトキャッシュ を確認し、 適切なエントリがなければ CORSプリフライトフェッチ を行い、成功すればキャッシュに登録する。 CORSプリフライトフェッチ の目的は 取得されるリソースが CORSプロトコルに対応していることを保証することである。 キャッシュは CORSプリフライトフェッチ の回数を減らすためにある。

    2. requestredirect mode が "follow" の場合、 requestservice-workers mode を "none" に設定する。

      ネットワーク由来のリダイレクト(サービスワーカー由来でない場合)はサービスワーカーに公開しない。

    3. responseinternalResponseHTTPネットワークまたはキャッシュフェッチfetchParams で実行した結果に設定する。

    4. requestresponse tainting が "cors" かつ CORSチェックrequestresponse で実行した結果が失敗の場合、 ネットワークエラー を返す。

      status が 304 または 407 の response や、サービスワーカーからの response には CORS チェック を適用しないため、ここで適用される。

    5. TAOチェックrequestresponse で実行した結果が失敗なら、 requesttiming allow failed flag を設定する。

  5. もし requestresponse tainting または responsetype が "opaque" であり、さらに cross-origin resource policy checkrequestoriginrequestclientrequestdestination、および internalResponse に対して実行した結果が blocked を返すなら、 network error を返す。

    cross-origin resource policy check は、 ネットワークからのレスポンスおよびサービスワーカーからのレスポンスに対して実行される。これは CORS check とは異なり、requestclient とサービスワーカーでは、異なる埋め込みポリシーを持ち得る。

  6. internalResponsestatusリダイレクトステータスの場合:

    1. internalResponsestatus が 303 でなく requestbody が null でなく connection が HTTP/2 を利用している場合、 ユーザーエージェントは RST_STREAM フレームを送信してもよい(推奨)。

      303 は特定コミュニティで特別視されるため除外されている。

    2. requestredirect mode に応じて:

      "error"
      1. responseネットワークエラー に設定する。

      "manual"
      1. requestmode が "navigate" の場合、 fetchParamscontrollernext manual redirect stepsHTTPリダイレクトフェッチfetchParamsresponse で実行する手順を設定する。

      2. それ以外の場合、 responseopaque-redirect filtered response に設定し、 その internal responseinternalResponse にする。

      "follow"
      1. responseHTTPリダイレクトフェッチfetchParamsresponse で実行した結果に設定する。

  7. response を返す。通常、internalResponsebodystream は この返却後もエンキューされ続けている。

4.5. HTTP リダイレクト フェッチ

HTTP-redirect fetchを、fetch params fetchParamsresponse response を与えて実行するには、次の手順を行う:

  1. request を、fetchParamsrequest とする。

  2. internalResponseresponse とする。ただし、responsefiltered response でない場合に限る。そうでない場合は responseinternal response とする。

  3. locationURL を、internalResponselocation URL とする。 これは、requestcurrent URLfragment を与えて得る。

  4. もし locationURL が null なら、response を返す。

  5. もし locationURL が failure なら、network error を返す。

  6. もし locationURLschemeHTTP(S) scheme でないなら、 network error を返す。

  7. もし requestredirect count が 20 なら、 network error を返す。

  8. requestredirect count を 1 増加させる。

  9. もし requestmode が "cors" で、 locationURLcredentials を含み、 かつ requestoriginlocationURLoriginsame origin でないなら、network error を返す。

  10. もし requestresponse tainting が "cors" であり、 かつ locationURLcredentials を含むなら、network error を返す。

    これは、クロスオリジンのリソースが同一オリジンの URL にリダイレクトする場合を検出する。

  11. もし internalResponsestatus が 303 でなく、requestbody が non-null であり、かつ requestbodysource が null なら、network error を返す。

  12. 次のいずれかが真である場合

    • internalResponsestatus が 301 または 302 で、 requestmethod が `POST` の場合

    • internalResponsestatus が 303 で、 requestmethod が `GET` または `HEAD` でない場合

    その場合:

    1. requestmethod を `GET` に設定し、 requestbody を null に設定する。

    2. headerNamerequest-body-header name)について、 削除 を行い、requestheader list から headerName を取り除く。

  13. もし requestcurrent URLorigin が、 locationURLoriginsame origin でないなら、 headerNameCORS non-wildcard request-header name)について、 削除 を行い、requestheader list から headerName を取り除く。

    すなわち、初期リクエスト後に別のオリジンが見えた瞬間に、 `Authorization` ヘッダーが削除される。

  14. もし requestbody が non-null なら、requestbody を、body に設定する。これは、 安全に抽出した requestbodysource の結果である。

    requestbodysource が null かどうかはすでに確認済みである。

  15. timingInfo を、fetchParamstiming info とする。

  16. timingInforedirect end timepost-redirect start time を、 coarsened shared current time に設定する。 これは、fetchParamscross-origin isolated capability を与えて得る。

  17. もし timingInforedirect start time が 0 なら、 timingInforedirect start timetimingInfostart time に設定する。

  18. Append(追加)を行い、locationURLrequestURL list に追加する。

  19. set request’s referrer policy on redirect を、request および internalResponse に対して呼び出す。[REFERRER]

  20. recursive を true とする。

  21. もし requestredirect mode が "manual" なら、 次を行う:

    1. Assert(断言): requestmode は "navigate" である。

    2. recursive を false に設定する。

  22. main fetch を、fetchParams および recursive を与えて実行した結果を返す。

    これは、requestmain fetch を呼び出して、 response tainting を正しく取得する必要がある。

4.6. HTTP ネットワークまたはキャッシュ フェッチ

HTTP-network-or-cache フェッチ を、fetch params fetchParams、オプショナルな boolean isAuthenticationFetch(デフォルトは false)、およびオプショナルな boolean isNewConnectionFetch(デフォルトは false)を与えて、次の手順を実行する:

一部の実装は HTTP Caching に従って部分的コンテンツのキャッシュをサポートするかもしれません。ただし、これはブラウザキャッシュでは広くサポートされていません。 [HTTP-CACHING]

  1. requestfetchParamsrequest とする。

  2. httpFetchParams を null とする。

  3. httpRequest を null とする。

  4. response を null とする。

  5. storedResponse を null とする。

  6. httpCache を null とする。

  7. revalidatingFlag を未設定とする。

  8. 次の手順を実行するが、abort when fetchParamscanceled の場合は中断する:

    1. もし requesttraversable for user prompts が "no-traversable" かつ requestredirect mode が "error" であれば、httpFetchParamsfetchParams を、httpRequestrequest を設定する。

    2. それ以外の場合:

      1. httpRequestrequestclone を設定する。

        実装は requestbodystream が null の場合(つまり単一ボディで十分な場合)は tee しないことが推奨されます。たとえば、requestbodysource が null なら、リダイレクトや認証時にフェッチは失敗します。

      2. httpFetchParamsfetchParams のコピーに設定する。

      3. httpFetchParamsrequesthttpRequest に設定する。

      ユーザープロンプトやリダイレクトが発生しうる場合、ユーザーの応答やリダイレクト先決定後に改めて新しいヘッダーでリクエストを送る必要があるかもしれません。その際、オリジナルのリクエストボディが一部送信済みとなっている可能性があるため、事前にリクエスト(ボディ含め)をクローンしてスペアを確保しておく必要があります。

    3. 次のいずれかの場合 includeCredentials を true とする:

      上記以外の場合は false とする。

    4. Cross-Origin-Embedder-Policy allows credentialsrequest で false を返す場合、includeCredentials を false に設定する。

    5. contentLengthhttpRequestbodylengthhttpRequestbody が null でない場合)、そうでなければ null とする。

    6. contentLengthHeaderValue を null とする。

    7. httpRequestbody が null かつ httpRequestmethod が `POST` または `PUT` の場合、contentLengthHeaderValue を `0` に設定する。

    8. contentLength が null でなければ contentLengthHeaderValuecontentLengthシリアライズisomorphic encode した値を設定する。

    9. contentLengthHeaderValue が null でなければ、append(`Content-Length`、contentLengthHeaderValue)を httpRequestheader list に追加する。

    10. contentLength が null でなく、httpRequestkeepalive が true ならば:

      1. inflightKeepaliveBytes を 0 とする。

      2. grouphttpRequestclientfetch group にする。

      3. inflightRecordsgroup 内で fetch records のうち、requestkeepalive が true かつ done flag が未設定なものの集合とする。

      4. For each fetchRecord of inflightRecords:

        1. inflightRequestfetchRecordrequest とする。

        2. inflightKeepaliveBytesinflightRequestbodylength を加算する。

      5. contentLengthinflightKeepaliveBytes の和が 64 kibibytes を超える場合、network error を返す。

      この制限により、bodyを含む環境設定オブジェクトの寿命を越えて生き残れるリクエストについてサイズが制限され、無限に生き残ることができなくなります。

    11. httpRequestreferrerURL の場合:

      1. referrerValuehttpRequestreferrerserialize かつ isomorphic encode した値とする。

      2. Append(`Referer`、referrerValue)を httpRequestheader list に追加する。

    12. Origin ヘッダーをリクエストに追加する。

    13. httpRequest の Fetch metadata ヘッダーを追加する。 [FETCH-METADATA]

    14. httpRequestinitiator が "prefetch" なら、structured field value を設定(`Sec-Purpose`、token prefetch)を httpRequestheader list にセットする。

    15. httpRequestheader list`User-Agent` を含まないとき、UAは:

      1. userAgenthttpRequestclient環境デフォルト `User-Agent` 値とする。

      2. Append(`User-Agent`、userAgent)を httpRequestheader list に追加する。

    16. httpRequestcache mode が "default" かつ httpRequestheader list が `If-Modified-Since` または `If-None-Match` または `If-Unmodified-Since` または `If-Match` または `If-Range` のいずれかを含むとき、 httpRequestcache mode を "no-store" に設定する。

    17. httpRequestcache mode が "no-cache", httpRequestprevent no-cache cache-control header modification flag が未設定、かつ httpRequestheader list`Cache-Control` を含まない場合、append(`Cache-Control`、`max-age=0`)を httpRequestheader list に追加する。

    18. httpRequestcache mode が "no-store" または "reload" の場合:

      1. httpRequestheader list`Pragma` を含まない場合、append(`Pragma`、`no-cache`)を httpRequestheader list に追加する。

      2. httpRequestheader list`Cache-Control` を含まない場合、append(`Cache-Control`、`no-cache`)を httpRequestheader list に追加する。

    19. httpRequestheader list`Range` を含む場合、append(`Accept-Encoding`、`identity`)を httpRequestheader list に追加する。

      これは、エンコード済みの response の一部で content codings の処理 を行う際の失敗を回避します。

      さらに、多くのサーバー は、非 identity のエンコーディングが許可されている場合に `Range` ヘッダーを誤って無視してしまうことがあります。

    20. HTTPに従い httpRequestheader list を修正する。与えられた headerhttpRequestheader list既に存在する場合は、append しない。

      ここの正規化を厳密にしたいところ。たとえば下記のようなヘッダー( `Accept-Encoding`、 `Connection`、 `DNT`、および `Host` など)は必要に応じてappend されることになります。

      ただしこの時点では `Accept`、 `Accept-Charset`, `Accept-Language` は含めてはいけません。

      `Accept` と `Accept-Language` は既に含まれています(fetch() を利用する場合、後者はデフォルトで含まれません)。また `Accept-Charset` は無駄なバイトです。詳細はHTTP header layer divisionも参照。

    21. includeCredentials が true の場合:

      1. リクエストの `Cookie` ヘッダーを追加する。

      2. httpRequestheader list`Authorization` を含まない場合:

        1. authorizationValue を null とする。

        2. もし httpRequest に対する authentication entry が存在し、かつ httpRequestuse-URL-credentials flag が未設定である、または httpRequestcurrent URLcredentials を含まない 場合、 authorizationValueauthentication entry に設定する。

        3. それ以外の場合で、httpRequestcurrent URLcredentials を含み、かつ isAuthenticationFetch が true のときは、 authorizationValuehttpRequestcurrent URL に、 `Authorization` 値に変換したものを設定する。

        4. もし authorizationValue が non-null なら、append を行い、 (`Authorization`, authorizationValue) を httpRequestheader list に追加する。

    22. proxy-authentication entry が存在する場合は、必要に応じてそれを利用する。

      ここは httpRequestcredentials mode には依存しない実装としています。

    23. httpCachedetermine the HTTP cache partition の結果(httpRequest を与えて呼ぶ)で設定する。

    24. httpCache が null なら httpRequestcache mode を "no-store" に設定する。

    25. httpRequestcache mode が "no-store" でも "reload" でもない場合:

      1. storedResponsehttpCache からレスポンスを選び、必要ならバリデーション処理し、HTTP Caching の "Constructing Responses from Caches" を参考に設定する。

        HTTPの規定により、`Vary` header も考慮されます。

      2. storedResponse が null でなければ:

        1. cache mode が "default" かつ storedResponsestale-while-revalidate response で、httpRequestclient が null でない場合:

          1. responsestoredResponse に設定する。

          2. responsecache state を "local" に設定する。

          3. revalidateRequestrequestclone で作成する。

          4. revalidateRequestcache mode を "no-cache" に設定する。

          5. revalidateRequestprevent no-cache cache-control header modification flag をセットする。

          6. revalidateRequestservice-workers mode を "none" に設定する。

          7. 並列でmain fetch を(fetch paramsrequestrevalidateRequest を与えて)実行する。

            この fetch は httpCache の状態更新専用で、その response は次回キャッシュアクセスまで使われません。staleなレスポンスが今回の応答に使われます。この fetch は client のコンテキストで発行されるため、clientが消えれば終了します。

        2. それ以外の場合:

          1. storedResponsestale response であれば revalidatingFlag をセットする。

          2. revalidatingFlag がセット済み かつ httpRequestcache mode が "force-cache" または "only-if-cached" のいずれでもなければ:

            1. storedResponseheader list`ETag` を含むとき、append(`If-None-Match`、`ETag` の value)を httpRequestheader list に追加する。

            2. storedResponseheader list`Last-Modified` を含むとき、append(`If-Modified-Since`、`Last-Modified` の value)を httpRequestheader list に追加する。

            "Sending a Validation Request" 章も参照。 HTTP Caching [HTTP-CACHING]

          3. それ以外は responsestoredResponse に、responsecache state を "local" に設定する。

  9. If aborted なら appropriate network errorfetchParams で返す。

  10. response が null の場合:

    1. httpRequestcache mode が "only-if-cached" の場合、network error を返す。

    2. forwardResponseHTTP-network fetchhttpFetchParams, includeCredentials, isNewConnectionFetch を与えて実行した結果とする。

    3. httpRequestmethodunsafe かつ forwardResponsestatus が 200〜399 の範囲なら httpCache の該当する storedResponses を "Invalidating Stored Responses" の規定に従い無効化し、storedResponse を null にする。[HTTP-CACHING]

    4. revalidatingFlag がセット済み かつ forwardResponsestatus が 304 なら:

      1. storedResponseheader list を、forwardResponseheader list で、"Freshening Stored Responses upon Validation" に従い更新する。

        これによりキャッシュ内の stored response も更新されます。

      2. responsestoredResponse に設定する。

      3. responsecache state を "validated" に設定する。

    5. response が null なら:

      1. responseforwardResponse に設定する。

      2. httpRequest および forwardResponsehttpCache に "Storing Responses in Caches" の規定で保存する。[HTTP-CACHING]

        forwardResponsenetwork error の場合、これは負のキャッシュ(negative caching)として扱われます。

        関連するbody info も response と一緒にキャッシュ保存されます。

  11. responseURL listhttpRequestURL listclone とする。

  12. httpRequestheader list`Range` を含む場合、responserange-requested flag をセットする。

  13. responserequest-includes-credentialsincludeCredentials に設定する。

  14. responsestatus が 401、httpRequestresponse tainting が "cors" 以外、includeCredentials が true、かつ requesttraversable for user promptstraversable navigable の場合:

    1. 要検証: 複数の `WWW-Authenticate` ヘッダー、欠落、パースエラー等。

    2. requestbody が null でない場合:

      1. requestbodysource が null なら network error を返す。

      2. requestbodybodysafely extracting requestbodysource 結果)のものに設定する。

    3. requestuse-URL-credentials flag が未設定または isAuthenticationFetch が true なら:

      1. fetchParamscanceled なら appropriate network errorfetchParams で返す。

      2. username および password をユーザーに requesttraversable for user prompts でプロンプトして取得する。

      3. Set the usernamerequestcurrent URL, username)を呼ぶ。

      4. Set the passwordrequestcurrent URL, password)を呼ぶ。

    4. HTTP-network-or-cache fetchfetchParams, true を与えて)を実行した結果を response に設定する。

  15. responsestatus が 407 の場合:

    1. requesttraversable for user prompts が "no-traversable" の場合 network error を返す。

    2. 要検証: 複数の `Proxy-Authenticate` ヘッダー、欠落、パースエラー等。

    3. fetchParamscanceled なら appropriate network errorfetchParams で返す。

    4. ユーザーにプロンプトし、その結果を proxy-authentication entry として保存する。[HTTP]

      プロキシ認証に関する詳細は HTTP に規定されています。

    5. HTTP-network-or-cache fetchfetchParams を与える)を実行した結果を response に設定する。

  16. 下記すべてが true なら:

    • responsestatus が 421

    • isNewConnectionFetch が false

    • requestbody が null または requestbody が null でなく requestbodysource が null でない

    場合:

    1. fetchParamscanceled なら appropriate network errorfetchParams で返す。

    2. HTTP-network-or-cache fetchfetchParams, isAuthenticationFetch, true を与えて)を実行した結果を response に設定する。

  17. isAuthenticationFetch が true なら authentication entryrequest と realm で作成する。

  18. response を返す。通常 responsebodystream には戻り値時点でまだ enqueue 中です。

4.7. HTTP-network フェッチ

HTTP-network fetchを、fetch params fetchParams、 オプションの boolean includeCredentials(デフォルト false)、およびオプションの boolean forceNewConnection(デフォルト false)を与えて実行するには、次の手順を行う:

  1. requestfetchParamsrequest とする。

  2. もし requestクライアントオフラインであれば、 ネットワークエラー を返す。

  3. response を null とする。

  4. timingInfofetchParamstiming info とする。

  5. networkPartitionKey を、request に対するネットワークパーティションキーの決定 を実行して得た結果とする。

  6. newConnection を、もし forceNewConnection が true なら "yes"、そうでなければ "no" にする。

  7. requestmode に応じて分岐する:

    "websocket"

    connection を、WebSocket 接続の取得requestcurrent URL を与えて)で得た結果とする。

    "webtransport"

    connection を、WebTransport 接続を取得する 処理に networkPartitionKeyrequest を渡して得られる結果とする。

    それ以外

    connection を、接続の取得networkPartitionKeyrequestcurrent URLincludeCredentials、および newConnection を与えて)で得た結果とする。

  8. 次の手順を実行する。ただし abort when fetchParamscanceled の場合は中止する:

    1. もし connection が failure なら、network error を返す。

    2. timingInfofinal connection timing info を、 clamp and coarsen connection timing infoconnectiontiming infotimingInfopost-redirect start time、 および fetchParamscross-origin isolated capability と共に呼び出した結果に設定する。

    3. もし connection が HTTP/1.x 接続で、かつ requestbody が non-null であり、かつその source が null なら、network error を返す。

    4. timingInfofinal network-request start time を、coarsened shared current timefetchParamscross-origin isolated capability を用いて得たもの)に設定する。

    5. connection 上で request を用いた HTTP リクエストを行い、その結果を response に設定する。ただし以下の注意を伴う:

      • HTTP に関する関連要件に従うこと。[HTTP] [HTTP-CACHING]

      • もし requestbody が non-null で、かつその source が null なら、ユーザーエージェントは最大 64 KiB のバッファを保持して request の一部の body をそこに保存してよい。もしユーザーエージェントがそのバッファサイズを超えて requestbody を読み、かつ再送が必要になった場合は、代わりに network error を返す。

        再送は例えば接続がタイムアウトしたときに必要になることがある。

        バッファは、もし requestbodysource が non-null の場合は不要である。なぜならその場合は body を再作成できるからである。

        もし requestbodysource が null であるなら、それは bodyReadableStream から作られていることを意味し、その場合 body を再作成できないためバッファが必要になる、ということである。

      • 次の処理を繰り返す:

        1. timingInfofinal network-response start time を、ユーザーエージェントの HTTP パーサがレスポンスの最初のバイトを受け取った直後(例:HTTP/2 のフレームヘッダバイトや HTTP/1.x のステータス行)に、coarsened shared current timefetchParamscross-origin isolated capability を用いて得たもの)に設定する。

        2. すべての HTTP レスポンスヘッダが送信されるまで待つ。

        3. status を HTTP レスポンスのステータスコードとする。

        4. もし status が 100〜199 の範囲にあるなら:

          1. もし timingInfofirst interim network-response start time が 0 なら、timingInfo の同名の値を timingInfofinal network-response start time に設定する。

          2. もし requestmode が "websocket" で、かつ status が 101 なら break する。

          3. もし status が 103 で、かつ fetchParamsprocess early hints response が non-null なら、queue a fetch task して fetchParams の同名の処理を response と共に実行する。

          4. Continue

          この種の HTTP レスポンスは最終的に "final" な HTTP レスポンスに続く。

        5. Break

      Fetch と HTTP の正確なレイヤリングは依然として整理が必要であり、そのため response はここでは response と HTTP レスポンスの両方を表します。

      もし HTTP リクエストが TLS クライアント証明書ダイアログを必要とする場合は、次を行う:

      1. もし requesttraversable for user promptstraversable navigable であれば、ダイアログをその requesttraversable for user prompts に表示可能にする。

      2. それ以外の場合、network error を返す。

      requestbody(ここでは body と呼ぶ)を送信するには、次の手順を実行する:

      1. もし body が null で、かつ fetchParamsprocess request end-of-body が non-null なら、queue a fetch task して fetchParams の同名の処理を fetchParamstask destination で実行する。

      2. それ以外で body が non-null の場合:

        1. processBodyChunkbytes を受け取る)を次の手順として定義する:

          1. もし fetchParamscanceled なら、これらの手順を中止する。

          2. このステップを in parallel で実行する:bytes を送信する。

          3. もし fetchParamsprocess request body chunk length が non-null なら、fetchParams の同名の処理を byteslength を与えて実行する。

        2. processEndOfBody を次の手順として定義する:

          1. もし fetchParamscanceled なら、中止する。

          2. もし fetchParamsprocess request end-of-body が non-null なら、それを実行する。

        3. processBodyError(引数 e)を次の手順として定義する:

          1. もし fetchParamscanceled なら中止する。

          2. もし e が "AbortError" DOMException であれば、abortfetchParamscontroller を中断する。

          3. それ以外の場合は、terminatefetchParamscontroller を終了する。

        4. Incrementally read を使って、requestbodyprocessBodyChunkprocessEndOfBodyprocessBodyError、および fetchParamstask destination を与えて逐次的に読み取る。

  9. If aborted なら、次を実行する:

    1. もし connection が HTTP/2 を使用しているなら、RST_STREAM フレームを送信する。

    2. fetchParams に対する appropriate network error を返す。

  10. buffer を空の byte sequence とする。

    これはユーザーエージェントのネットワークレイヤ内部の内部バッファを表す。

  11. stream を新しい ReadableStream とする。

  12. pullAlgorithm を次の手順とする:

    1. promise新しい Promise とする。

    2. 次の手順を 並行して 実行する:

      1. もし buffer のサイズがユーザーエージェントが選んだ下限より小さく、かつ 現在のフェッチが suspended であるなら、フェッチを resume する。

      2. buffer が空でなくなるまで待つ。

      3. Queue a fetch task して、以下を fetchParamstask destination で実行する。

        1. Pull from bytesbuffer から stream にデータを引き出す。

        2. もし streamerrored なら、terminatefetchParamscontroller を終了する。

        3. Resolve promise を undefined で完了する。

    3. promise を返す。

  13. cancelAlgorithm を、与えられた reason に対して abort を行い fetchParamscontroller を中断するアルゴリズムとする。

  14. Set upstream をバイト読み取り対応でセットアップし、pullAlgorithmpullAlgorithmcancelAlgorithmcancelAlgorithm に設定する。

  15. responsebody を、新しい body に設定し、その streamstream にする。

  16. (This is a tracking vector.) もし includeCredentials が true なら、ユーザーエージェントは requestresponse を与えて レスポンスの `Set-Cookie` ヘッダをパースして保存 すべきである。

  17. 次の手順を 並行して 実行する:

    1. 次の手順を実行する。ただし abort when fetchParamscanceled の場合は中止する:

      1. 繰り返し実行する:

        1. もし response のメッセージ本文から 1 バイト以上が送信されているなら:

          1. bytes を送信されたバイトとする。

          2. codings を、`Content-Encoding` と responseheader list から header list values を抽出 した結果とする。

          3. filteredCoding を "@unknown" にする。

          4. もし codings が null または failure なら filteredCoding を空文字にする。

          5. そうでなく、かつ codingssize が 1 より大きければ、filteredCoding を "multiple" にする。

          6. それ以外で、もし codings[0] が空文字、またはユーザーエージェントがサポートしており、かつ バイトケース非区別 な比較で HTTP Content Coding Registry に記載されたエントリに一致するなら、filteredCodingbyte-lowercasing を行った codings[0] にする。[IANA-HTTP-PARAMS]

          7. responsebody infocontent encodingfilteredCoding に設定する。

          8. responsebody infoencoded sizebyteslength だけ増やす。

          9. bytes を、handle content codingscodings と共に与えて処理した結果にする。

            これにより `Content-Length` ヘッダの信頼性が、元々の信頼性に応じて損なわれる可能性がある。

          10. responsebody infodecoded sizebyteslength だけ増やす。

          11. もし bytes が failure なら、terminatefetchParamscontroller を終了する。

          12. bytesbuffer に追記する。

          13. もし buffer のサイズがユーザーエージェントが選んだ上限より大きければ、ユーザーエージェントに継続中のフェッチを suspend するよう要求する。

        2. それ以外で、もし response のメッセージ本文のバイト送信が正常に完了しており、かつ streamreadable なら、closestream を閉じ、これらの並行ステップを中止する。

    2. If aborted なら、次を実行する:

      1. もし fetchParamsaborted なら、次を実行する:

        1. responseaborted flag を設定する。

        2. もし streamreadable なら、errorstream を、fetchParamscontrollerserialized abort reasondeserialize a serialized abort reason に渡した結果と実装定義の realm を用いてエラー化する。

      2. それ以外で、もし streamreadable なら、errorstream を TypeError にする。

      3. もし connection が HTTP/2 を使用しているなら、RST_STREAM フレームを送信する。

      4. それ以外の場合、パフォーマンス上問題がない限りユーザーエージェントは connection を閉じるべきである。

        例えば、再利用可能な接続で残りの転送がごく少量とわかっている場合、接続を閉じて次のフェッチでハンドシェイクをやり直すよりも、接続を開いたままにしておくほうが良いことがある。

    これらは並行して実行される。現時点では responsebody が関連するかどうか不明(response がリダイレクトである可能性がある)ためである。

  18. response を返す。通常、responsebodystream は返却後もエンキューされ続ける。

4.8. CORSプリフライトフェッチ

これは実質的に、CORSプロトコルが理解されているかどうかを確認するためのユーザーエージェント実装である。いわゆるCORSプリフライトリクエスト。成功すると、CORSプリフライトキャッシュに登録され、このフェッチの回数を最小限に抑える。

CORS-プレフライト フェッチを、リクエスト request に対して行うには、次の手順を実行する:

  1. preflight を新しい リクエスト とし、 メソッド は `OPTIONS`、 URLリストrequestURLリストクローンinitiatorrequestinitiatordestinationrequestdestinationoriginrequestoriginreferrerrequestreferrerreferrer policyrequestreferrer policymode は "cors"、および response tainting は "cors" とする。

    preflight の service-workers mode は 本アルゴリズムが HTTP-network-or-cache fetch を 使用するため重要ではない。HTTP fetch ではない。

  2. 追加する (`Accept`, `*/*`) を preflightヘッダーリスト に追加する。

  3. 追加する (`Access-Control-Request-Method`、 requestmethod)を preflightヘッダーリスト に追加する。

  4. headersCORS-unsafe request-header names with requestheader list とする。

  5. もし headers空でない 場合:

    1. valueheaders の各要素を `,` で区切ったものとする。

    2. 追加する (`Access-Control-Request-Headers`、 value)を preflightヘッダーリスト に追加する。

    意図的に combine を使わない(0x2C の後の 0x20 をこのように実装されたため、良し悪しは別として)

  6. response を新しい fetch paramsrequest は preflight として HTTP-network-or-cache fetch の結果とする。

  7. CORS チェック を request, response で行い成功し、 responsestatusok status の場合:

    CORS チェック は preflight ではなく request に対して 適切な credentials mode を 使うために実行される。

    1. methods を、extracting header list values を `Access-Control-Allow-Methods` と responseheader list で行った結果とする。

    2. headerNamesextracting header list values を `Access-Control-Allow-Headers` と responseheader list で行った結果とする。

    3. methods または headerNames が failure なら network error を返す。

    4. methods が null で request の use-CORS-preflight flag がセットされている場合、methods を request の method を含む新しいリストにする。

      この場合、use-CORS-preflight flag により CORS-プレフライト フェッチの結果がキャッシュされる。

    5. もし requestmethodmethods に含まれておらず、 requestmethodCORS-セーフリストメソッド でなく、 requestcredentials mode が "include" である、または methods に `*` が含まれていない場合、network error を返す。

    6. request の header listnames のいずれかが CORS non-wildcard request-header name であり、かつ headerNames の item とバイト大文字小文字を区別せず一致しない場合は network error を返す。

    7. request の CORS-unsafe request-header names を走査し、 unsafeNameheaderNames のいずれともバイト大文字小文字を区別せず一致せず、 かつ request の credentials mode が "include" である または headerNames に `*` が含まれていない場合、 network error を返す。

    8. max-age を `Access-Control-Max-Age` と response の header list で extracting header list values を 実行した結果とする。

    9. max-age が failure または null の場合、max-age を 5 に設定する。

    10. max-age が許容上限値より大きい場合、max-age を上限値に設定する。

    11. UA が キャッシュ を提供していない場合、 response を返す。

    12. request で method cache entry match が存在する各 methods に対して entry の max-age を max-age に設定する。

    13. request で method cache entry match が存在しない各 methods に対して 新しい cache entry を作成し、request, max-age, method, null を設定する。

    14. request で header-name cache entry match が存在する各 headerNames に対して entry の max-age を max-age に設定する。

    15. request で header-name cache entry match が存在しない各 headerNames に対して 新しい cache entry を作成し、request, max-age, null, headerName を設定する。

    16. response を返す。

  8. それ以外の場合は network error を返す。

4.9. CORSプリフライトキャッシュ

ユーザーエージェントには CORSプレフライトキャッシュ が関連付けられている。 CORSプレフライトキャッシュリスト であり、 キャッシュエントリ のリストである。

キャッシュエントリ は次から成る:

キャッシュエントリmax-age フィールドに指定された秒数が 記録から経過した後、削除されなければならない。キャッシュエントリ は それ以前にも削除されてもよい。

新しいキャッシュエントリを作成するには、 requestmax-agemethodheaderName を与えて次の手順を実行する:

  1. entryキャッシュエントリ とし、以下のように初期化する:

    キー

    ネットワークパーティションキーを決定するrequest による結果

    バイト列化されたオリジン

    リクエストオリジンのバイト列化request で実行した結果

    URL

    requestcurrent URL

    max-age

    max-age

    クレデンシャル

    requestcredentials mode が "include" の場合 true、 それ以外は false

    メソッド

    method

    ヘッダー名

    headerName

  2. entry をユーザーエージェントの CORSプレフライトキャッシュ に追加する。

キャッシュエントリを消去するには、request を与え、 ユーザーエージェントの CORSプレフライトキャッシュ 内の キャッシュエントリ で、 keyrequest でネットワークパーティションキーを決定 した結果と一致し、 バイト列化されたオリジンrequest でリクエストオリジンのバイト列化 の結果と一致し、 URLrequestcurrent URL であるエントリを 削除 する。

キャッシュエントリ entryrequest一致するとは、 entrykeyrequest でネットワークパーティションキーを決定 した結果と一致し、 entryバイト列化されたオリジンrequest でリクエストオリジンのバイト列化 の結果と一致し、 entryURLrequestcurrent URL であり、さらに以下のいずれかが成り立つ場合を指す。

が真である。

メソッドキャッシュエントリが一致する とは、methodrequest を与えたとき、 ユーザーエージェントの CORSプレフライトキャッシュ 内に request との キャッシュエントリの一致 があり、 その メソッドmethod または `*` である キャッシュエントリ が存在することである。

ヘッダー名キャッシュエントリが一致する とは、 headerNamerequest を与えたとき、 ユーザーエージェントの CORSプレフライトキャッシュ 内の キャッシュエントリrequest との キャッシュエントリの一致 があり、次のいずれかが成り立つときである:

が真である。

4.10. CORSチェック

CORSチェックrequestresponse で実行するには、以下の手順を行う:

  1. originresponseheader list から `Access-Control-Allow-Origin` を 取得した結果とする。

  2. origin が null なら failure を返す。

    null は `null` とは異なる。

  3. requestcredentials mode が "include" でなく、かつ origin が `*` の場合、success を返す。

  4. request に対して リクエストオリジンのバイト列化 を実行した結果が origin でなければ failure を返す。

  5. requestcredentials mode が "include" でなければ success を返す。

  6. credentialsresponseheader list から `Access-Control-Allow-Credentials` を 取得した結果とする。

  7. credentials が `true` なら success を返す。

  8. failure を返す。

4.11. TAOチェック

requestresponse に対して TAO チェック を実行するには、次の手順を行う:

  1. アサートrequestorigin は "client" であってはならない。

  2. もし requesttiming allow failed flag がセットされているなら、失敗を返す。

  3. values を、`Timing-Allow-Origin` を取得・デコード・分割responseheader list に対して行った結果とする。

  4. もし values"*" を含む なら、成功を返す。

  5. もし values含む 場合、 request オリジンをシリアライズした結果request を用いて)を、 成功を返す。

  6. もし requestmode が "navigate" であり、 requestcurrent URLoriginrequestorigin同一生成元でないなら、失敗を返す。

    これは入れ子 navigable のナビゲーションのために必要です。 この場合 requestorigin はコンテナドキュメントの origin となり、 TAO チェック は失敗を返すことになる。 ナビゲーションタイミングは TAO チェック の結果を検証しないため、 入れ子のドキュメントにはタイミング情報すべてにアクセス可能だが、 コンテナドキュメントには与えられない。

  7. もし requestresponse tainting が "basic" なら、成功を返す。

  8. 失敗を返す。

4.12. 遅延フェッチ

遅延フェッチは、呼出し元が可能な限り遅いタイミング、すなわちフェッチグループ終了する時や タイムアウト後などにフェッチを行うよう要求できるようにする。

遅延フェッチタスクソースは、 遅延フェッチの結果を更新するために使われる タスクソース である。ユーザーエージェントはこの タスクソース のタスクを、他のタスクソース、 特にDOM操作タスクソースなどスクリプトの実行につながる タスクソースよりも優先して処理しなければならない。これは fetchLater() の呼び出しの最新状態が、依存するかもしれないスクリプトより前に反映されるようにするためである。

遅延フェッチをキューする には、request request、null または DOMHighResTimeStamp activateAfter、引数を取らないアルゴリズム onActivatedWithoutTermination を指定して、次の手順を実行する:

  1. クライアントから request を補完するrequest で行う。

  2. requestservice-workers mode を "none" に設定する。

  3. requestkeepalive を true に設定する。

  4. deferredRecord を新しい 遅延フェッチレコード とし、 requestrequestnotify invokedonActivatedWithoutTermination とする。

  5. deferredRecord を requestclientfetch groupdeferred fetch records に追加する。

  6. activateAfter が null でない場合は、次の手順を 並列で実行する:

    1. ユーザーエージェントは次のいずれかの条件が満たされるまで待機すべきである:

    2. deferredRecord を処理する。

  7. deferredRecord を返す。

リクエスト全体長を計算するには request request に対して次の手順を実行する:

  1. totalRequestLength を、requestURLシリアライズし、 フラグメント除外 を true にした時の 長さ とする。

  2. totalRequestLengthrequestreferrerシリアライズした 長さ を加算する。

  3. request の header list の (name, value) ごとに、 totalRequestLengthname長さ + value長さ を加算する。

  4. totalRequestLength に、requestbody長さを加算する。

  5. totalRequestLength を返す。

遅延フェッチを処理するには fetch group fetchGroup について以下を実行する:

  1. fetchGroup の deferred fetch recordsdeferredRecord として1つずつ process a deferred fetch deferredRecord を実行する。

遅延フェッチを処理するには deferredRecord について以下を実行する:

  1. deferredRecord の invoke state が "pending" でない場合は return する。

  2. deferredRecord の invoke state を "sent" に設定する。

  3. フェッチ deferredRecord の request を行う。

  4. グローバルタスクを 遅延フェッチタスクソース で、 deferredRecord の requestclientグローバルオブジェクト へ queued し、deferredRecord の notify invoked を実行する。

4.12.1. 遅延フェッチのクォータ

この節は規範的ではありません。

遅延フェッチクォータは、トップレベルトラバーサブル(「タブ」)ごとに640キビバイト割り当てられます。 トップレベル文書と同一オリジンの直接ネスト文書はこのクォータを使って遅延フェッチをキューしたり、パーミッションポリシーを使って一部をクロスオリジンのネスト文書に委譲したりできます。

デフォルトでは、640キビバイトのうち128キビバイトがクロスオリジンのネスト文書への委譲に割り当てられ、各文書は8キビバイトを予約します。

トップレベルのdocumentおよびそのネスト文書は、パーミッションポリシーを使って自身のクォータのうちどれだけをクロスオリジンの子文書に委譲するかを制御できます。デフォルトでは、 "deferred-fetch-minimal" ポリシーは任意のオリジンに対して有効、 "deferred-fetch" はトップレベル文書のオリジンだけに有効です。特定のオリジンやネスト文書に対して "deferred-fetch" ポリシーを緩和すれば、そのネスト文書に64キビバイトを割り当てられます。同様に "deferred-fetch-minimal" ポリシーを特定のオリジンやネスト文書に対して制限すれば、その文書がデフォルトで受け取る8キビバイト予約を防ぐことができます。トップレベル文書自身に "deferred-fetch-minimal" ポリシーを無効化すれば、128キビバイトの委譲クォータがメインプール(640キビバイト)に戻されます。

あるdocumentに割り当てられたクォータのうち、同じレポートオリジン(requestURLorigin)に同時に使えるのは64キビバイトだけです。これにより、特定のサードパーティーライブラリがデータ送信前に機会的にクォータを予約してしまう事態を防げます。

以下のいずれかのfetchLater()呼び出しは、リクエスト自体がレポートオリジンに割り当てられた64キビバイトクォータを超えるためthrowされます。リクエストのサイズはURL自体、bodyheader listreferrerを含みます。

fetchLater(a_72_kb_url);
fetchLater("https://origin.example.com", {headers: headers_exceeding_64kb});
fetchLater(a_32_kb_url, {headers: headers_exceeding_32kb});
fetchLater("https://origin.example.com", {method: "POST", body: body_exceeding_64_kb});
fetchLater(a_62_kb_url /* with a 3kb referrer */);

次のシーケンスでは、最初の2つのリクエストは成功しますが、3つ目はthrowされます。最初の2回の呼び出しでは全体の640キビバイトクォータは超えていませんが、3つ目のリクエストはhttps://a.example.comのレポートオリジンクォータを超えるためthrowされます。

fetchLater("https://a.example.com", {method: "POST", body: a_64kb_body});
fetchLater("https://b.example.com", {method: "POST", body: a_64kb_body});
fetchLater("https://a.example.com");

同一オリジンのネスト文書は親のクォータを共有します。しかし、クロスオリジンやクロスエージェントiframeはデフォルトで8キビバイトしか割り当てられません。従って、以下の例では最初の3回の呼び出しは成功し、最後はthrowされます。

// メインページ内
fetchLater("https://a.example.com", {method: "POST", body: a_64kb_body});

// 同一オリジンのネスト文書内
fetchLater("https://b.example.com", {method: "POST", body: a_64kb_body});

// https://fratop.example.com のクロスオリジンネスト文書内
fetchLater("https://a.example.com", {body: a_5kb_body});
fetchLater("https://a.example.com", {body: a_12kb_body});

前述の例でthrowされないようにするには、トップレベル文書が例えば以下のヘッダーを送信してhttps://fratop.example.comへクォータを委譲します:

Permissions-Policy: deferred-fetch=(self "https://fratop.example.com")

各ネスト文書は自身のクォータを予約します。したがって、下記のように各フレームが8キビバイトずつ予約するため動作します:

// https://fratop.example.com/frame-1 のクロスオリジンネスト文書内
fetchLater("https://a.example.com", {body: a_6kb_body});

// https://fratop.example.com/frame-2 のクロスオリジンネスト文書内
fetchLater("https://a.example.com", {body: a_6kb_body});

以下のツリーは異なるネスト文書にクォータがどのように分配されるかを示します:

上記の例では、トップレベル遷移可能とその同一オリジンの子孫は384キビバイトのクォータを共有します。その値は以下のように計算されます:

この仕様は、文字列"deferred-fetch"で識別されるポリシー制御機能を定義します。そのデフォルト許可リストは"self"です。

この仕様は、文字列"deferred-fetch-minimal"で識別されるポリシー制御機能を定義します。そのデフォルト許可リストは"*"です。

deferred-fetch-minimal用に予約されたクォータは128キビバイトです。

ナビゲーション可能コンテナは関連付けられた数値遅延フェッチ用予約クォータを持ちます。その値はミニマルクォータ(8キビバイト)、ノーマルクォータ(0または64キビバイト)。特に記載がない場合は0です。

利用可能な遅延フェッチクォータ を、document document と、origin-または-null の origin を指定して取得するには:

  1. controlDocumentdocument遅延フェッチ制御文書を設定する。

  2. navigablecontrolDocumentノード遷移可能を設定する。

  3. isTopLevelcontrolDocumentノード遷移可能トップレベル遷移可能ならtrue、そうでなければfalseを設定する。

  4. deferredFetchAllowedcontrolDocumentが"deferred-fetch"ポリシー制御機能の利用を許可されていればtrue、そうでなければfalseを設定する。

  5. deferredFetchMinimalAllowedcontrolDocumentが"deferred-fetch-minimal"ポリシー制御機能の利用を許可されていればtrue、そうでなければfalseを設定する。

  6. quotaに最初に一致する条件の結果を設定する:

    isTopLevelがtrueかつdeferredFetchAllowedがfalse
    0
    isTopLevelがtrueかつdeferredFetchMinimalAllowedがfalse

    640キビバイト

    640kbはみんなに十分なはずです。

    isTopLevelがtrue

    512キビバイト

    デフォルト640キビバイトからdeferred-fetch-minimal用予約クォータ分を減算した値

    deferredFetchAllowedがtrueかつnavigableナビゲーション可能コンテナ遅延フェッチ用予約クォータノーマルクォータ
    ノーマルクォータ
    deferredFetchMinimalAllowedがtrueかつnavigableナビゲーション可能コンテナ遅延フェッチ用予約クォータミニマルクォータ
    ミニマルクォータ
    それ以外
    0
  7. quotaForRequestOriginに64キビバイトを設定する。

  8. navigablecontrolDocumentノード遷移可能包括的子孫遷移可能で、アクティブ文書遅延フェッチ制御文書controlDocumentであるもの)について:

    1. containernavigableアクティブ文書shadow-including包括的子孫のうちナビゲーション可能コンテナ)について、quotaからcontainer遅延フェッチ用予約クォータを減算する。

    2. deferred fetch recorddeferredRecordnavigableアクティブ文書関連設定オブジェクトfetch groupdeferred fetch records)について:

      1. requestLengthdeferredRecordrequest総リクエスト長を設定する。

      2. quotaからrequestLengthを減算する。

      3. deferredRecordrequestURLoriginorigin同一オリジンであれば、quotaForRequestOriginからrequestLengthを減算する。

  9. quotaが0以下なら0を返す。

  10. quotaquotaForRequestOrigin未満ならquotaを返す。

  11. quotaForRequestOriginを返す。

遅延フェッチクォータの予約は、ナビゲーション可能コンテナcontaineroriginoriginToNavigateToを指定して以下を実行します:

これはナビゲーション時、ナビゲーション元文書がnavigableの親文書である場合に呼ばれます。パーミッションポリシーで許可されていれば、コンテナおよびそのナビゲーション可能要素に最大64kbまたは8kbのクォータを予約します。予約されたクォータが実際に使われたかどうかはコンテナ文書から観測できません。このアルゴリズムは、コンテナの文書がナビゲート先コンテナにクォータを委譲する可能性があると仮定し、予約されたクォータはその場合のみ適用され、共有されることになった場合は無視されます。クォータが予約され、その文書が親と同一オリジンとなった場合、クォータは解放されます。

  1. container遅延フェッチ用予約クォータを0に設定する。

  2. controlDocumentcontainerノード文書遅延フェッチ制御文書を設定する。

  3. "deferred-fetch" の継承ポリシーcontainer, originToNavigateTo)が"Enabled"であり、controlDocument利用可能な遅延フェッチクォータノーマルクォータ以上であれば、container遅延フェッチ用予約クォータノーマルクォータに設定してreturnする。

  4. 以下すべてが真の場合:

    この場合、container遅延フェッチ用予約クォータミニマルクォータに設定する。

遅延フェッチクォータの解放(可能性あり)は、文書documentに対して、documentノード遷移可能コンテナ文書がnullでなく、かつそのorigindocument同一オリジンであれば、documentノード遷移可能navigable container遅延フェッチ用予約クォータを0に設定する。

これは文書が生成されたときに呼ばれます。同一オリジンのネスト文書は親クォータを共有するため予約しません。これは文書生成時のみ呼ばれ、originはリダイレクト処理後にのみ判明するためです。

遅延フェッチ制御文書の取得は、文書documentについて以下を実行する:

  1. documentノード遷移可能コンテナ文書がnullまたは、文書で、そのorigindocument同一オリジンでなければ、documentを返し、それ以外の場合はdocumentノード遷移可能コンテナ文書について再帰的に遅延フェッチ制御文書の取得を実行する。

5. Fetch API(フェッチAPI)

fetch()メソッドは、リソースの取得のための比較的低レベルなAPIです。現行標準ではXMLHttpRequestよりも少し広い範囲をカバーしますが、リクエスト進行状況(レスポンス進行状況ではなく)の点ではまだ不十分です。

fetch()メソッドは、リソースを取得してその内容をBlobとして抽出するのを非常に簡単にします:

fetch("/music/pk/altes-kamuffel.flac")
  .then(res => res.blob()).then(playBlob)

特定のレスポンスヘッダーだけを記録したい場合:

fetch("/", {method:"HEAD"})
  .then(res => log(res.headers.get("strict-transport-security")))

クロスオリジンリソースの特定のレスポンスヘッダーを確認し、そのあとレスポンスを処理したい場合:

fetch("https://pk.example/berlin-calling.json", {mode:"cors"})
  .then(res => {
    if(res.headers.get("content-type") &&
       res.headers.get("content-type").toLowerCase().indexOf("application/json") >= 0) {
      return res.json()
    } else {
      throw new TypeError()
    }
  }).then(processJSON)

URLクエリパラメータを扱いたい場合:

var url = new URL("https://geo.example.org/api"),
    params = {lat:35.696233, long:139.570431}
Object.keys(params).forEach(key => url.searchParams.append(key, params[key]))
fetch(url).then(/* … */)

ボディデータを逐次受信したい場合:

function consume(reader) {
  var total = 0
  return pump()
  function pump() {
    return reader.read().then(({done, value}) => {
      if(done) {
        return
      }
      total += value.byteLength
      log(`received ${value.byteLength} bytes (${total} bytes in total)`)
      return pump()
    })
  }
}

fetch("/music/pk/altes-kamuffel.flac")
  .then(res => consume(res.body.getReader()))
  .then(() => log("全データをメモリに保持せずにボディ全体を消費しました!"))
  .catch(e => log("何か問題が発生しました: " + e))

5.1. Headersクラス

typedef (sequence<sequence<ByteString>> or record<ByteString, ByteString>) HeadersInit;

[Exposed=(Window,Worker)]
interface Headers {
  constructor(optional HeadersInit init);

  undefined append(ByteString name, ByteString value);
  undefined delete(ByteString name);
  ByteString? get(ByteString name);
  sequence<ByteString> getSetCookie();
  boolean has(ByteString name);
  undefined set(ByteString name, ByteString value);
  iterable<ByteString, ByteString>;
};

Headers オブジェクトは、 関連付けられた ヘッダーリストheader list)を持つ。 これは初期状態では空である。これは他のもの、例えば header listへのポインタでもよく、 Request オブジェクトの request の場合が例である。

Headersオブジェクトには、さらに関連付けられたガードheaders guard)があります。headers guardは、"immutable"、"request"、"request-no-cors"、"response"、"none"のいずれかです。


headers = new Headers([init])

新しいHeadersオブジェクトを生成します。initで内部のヘッダーリストを初期化できます(下記例参照)。

const meta = { "Content-Type": "text/xml", "Breaking-Bad": "<3" };
new Headers(meta);

// 上記と同等
const meta2 = [
  [ "Content-Type", "text/xml" ],
  [ "Breaking-Bad", "<3" ]
];
new Headers(meta2);
headers . append(name, value)

headersにヘッダーを追加します。

headers . delete(name)

headersからヘッダーを削除します。

headers . get(name)

nameと一致する全ヘッダー値を、カンマ+スペース区切りで文字列として返します。

headers . getSetCookie()

`Set-Cookie`名の全ヘッダー値リストを返します。

headers . has(name)

nameという名前のヘッダーが存在するかどうかを返します。

headers . set(name, value)

最初に一致したnameのヘッダー値をvalueに置換し、残りの同名ヘッダーは削除します。

for(const [name, value] of headers)

headersは反復処理可能です。


バリデートヘッダーname, value))をHeadersオブジェクトheadersに対して行うには:

  1. nameヘッダー名でない、またはvalueヘッダー値でない場合、TypeError例外を投げる。

  2. headersガードが"immutable"なら、TypeError例外を投げる。

  3. headersガードが"request"かつ(name, value)が禁止リクエストヘッダーなら、falseを返す。

  4. headersガードが"response"かつname禁止レスポンスヘッダー名なら、falseを返す。

  5. trueを返す。

"request-no-cors"の手順は共有されません。なぜならCORS安全リストリクエストヘッダーに対して常に成功する偽の値(delete()用)を持つことができないためです。

追加ヘッダーname, value))をHeadersオブジェクトheadersに対して行うには、以下を実行する:

  1. value正規化する。

  2. バリデートname, value)がheadersでfalseなら、returnする。

  3. headersガードが"request-no-cors"なら:

    1. temporaryValueheadersheader listからname取得した結果を設定する。

    2. temporaryValueがnullなら、temporaryValuevalueに設定する。

    3. それ以外の場合、temporaryValuetemporaryValue+「, 」+valueに設定する。

    4. name, temporaryValue)がno-CORS安全リストリクエストヘッダーでない場合、returnする。

  4. 追加name, value)をheadersheader listに対して実行する。

  5. headersガードが"request-no-cors"なら、特権no-CORSリクエストヘッダーの削除headersに対して実行する。

fillHeadersオブジェクトheaders、与えられたオブジェクトobject)は以下を実行する:

  1. objectsequenceなら、headerobjectの要素)について:

    1. headersizeが2でなければ、TypeError例外を投げる。

    2. 追加header[0], header[1])をheadersに対して実行する。

  2. それ以外の場合、objectrecordなら、keyvalueobjectの要素)について、追加key, value)をheadersに対して実行する。

特権no-CORSリクエストヘッダーの削除Headersオブジェクト(headers))は以下を実行する:

  1. headerName特権no-CORSリクエストヘッダー名)について:

    1. 削除headerName)をheadersheader listに対して実行する。

これは、特権のないコードによってヘッダーが変更された時に呼ばれます。

new Headers(init) コンストラクタの手順は次の通りです:

  1. thisガードを"none"に設定する。

  2. initが与えられていれば、fillthisinit)を実行する。

append(name, value) メソッドの手順は、追加name, value)をthisに対して行うこと。

delete(name)メソッドの手順は以下の通りです:

  1. バリデートname, ``)がthisでfalseなら、returnする。

    ダミーのヘッダー値を渡しても悪影響はありません。

  2. thisガードが"request-no-cors"、かつnameno-CORS安全リストリクエストヘッダー名でも特権no-CORSリクエストヘッダー名でもない場合、returnする。

  3. thisheader listname含まない場合、returnする。

  4. 削除name)をthisheader listに対して実行する。

  5. thisガードが"request-no-cors"なら、特権no-CORSリクエストヘッダーの削除thisに対して実行する。

get(name)メソッドの手順は以下の通りです:

  1. nameヘッダー名でない場合、TypeError例外を投げる。

  2. name取得thisheader listから)し、その結果を返す。

getSetCookie()メソッドの手順は以下の通りです:

  1. thisheader listが`Set-Cookie`を含まない場合、« »を返す。

  2. thisheader listのうち、nameが`Set-Cookie`とバイト大文字小文字無視で一致するヘッダー)の値を順序通り返す。

has(name)メソッドの手順は以下の通りです:

  1. nameヘッダー名でない場合、TypeError例外を投げる。

  2. thisheader listname含むならtrue、そうでなければfalseを返す。

set(name, value) メソッドの手順は以下の通りです:

  1. value正規化する。

  2. バリデートname, value)がthisでfalseなら、returnする。

  3. thisガードが"request-no-cors"かつ(name, value)がno-CORS安全リストリクエストヘッダーでない場合、returnする。

  4. セットname, value)をthisheader listに対して実行する。

  5. thisガードが"request-no-cors"なら、特権no-CORSリクエストヘッダーの削除thisに対して実行する。

反復対象の値ペアは、ソートおよび結合thisheader list)の実行結果です。

5.2. BodyInit ユニオン型

typedef (Blob or BufferSource or FormData or URLSearchParams or USVString) XMLHttpRequestBodyInit;

typedef (ReadableStream or XMLHttpRequestBodyInit) BodyInit;

安全抽出は、型付きbodyバイト列またはBodyInitオブジェクトobjectから抽出するための手順です:

  1. objectReadableStream オブジェクトなら:

    1. アサートobjectdisturbedでもlockedでもないこと。

  2. extractobject)の結果を返す。

安全抽出操作は、例外を投げないことが保証されるextract操作のサブセットです。

extractは、 型付きbodyバイト列またはBodyInitオブジェクトobjectから抽出するための手順です。オプションのブール値 keepalive(デフォルトfalse)を受け取ります:

  1. streamをnullに設定する。

  2. objectReadableStream オブジェクトなら、streamobjectを設定する。

  3. それ以外でobjectBlob オブジェクトなら、streamobjectget streamの結果を設定する。

  4. それ以外の場合、streamに新しいReadableStreamオブジェクトを設定し、 バイト読み取り対応でセットアップする。

  5. アサートstreamReadableStreamオブジェクトであること。

  6. actionをnullに設定する。

  7. sourceをnullに設定する。

  8. lengthをnullに設定する。

  9. typeをnullに設定する。

  10. objectの型によって分岐:

    Blob

    sourceobjectを設定する。

    lengthobjectsize属性値を設定する。

    objecttype属性値が空でなければ、typeにその値を設定する。

    バイト列

    sourceobjectを設定する。

    BufferSource

    sourceobjectが保持するバイトのコピーを設定する。

    FormData

    actionに次の手順:multipart/form-dataエンコーディングアルゴリズムobjectentry listUTF-8で実行する、を設定する。

    sourceobjectを設定する。

    length未確定、詳細は html/6424参照を設定する。

    typeに`multipart/form-data; boundary=`+multipart/form-data境界文字列multipart/form-dataエンコーディングアルゴリズムで生成)を設定する。

    URLSearchParams

    sourceapplication/x-www-form-urlencodedシリアライザobjectlistを使う)を実行した結果を設定する。

    typeに`application/x-www-form-urlencoded;charset=UTF-8`を設定する。

    スカラー値文字列

    sourceUTF-8エンコードobject)の結果を設定する。

    typeに`text/plain;charset=UTF-8`を設定する。

    ReadableStream

    keepaliveがtrueなら、TypeError例外を投げる。

    objectdisturbedまたはlockedなら、TypeError例外を投げる。

  11. sourceバイト列なら、actionに「sourceを返す」手順を設定し、lengthsourcelengthを設定する。

  12. actionがnullでなければ、以下の手順を並列で実行する:

    1. actionを実行する。

      バイトが1つ以上利用可能になり、かつstreamerroredでなければ、enqueue(利用可能なバイトからUint8Arrayを生成した結果、stream)を行う。

      actionが終了したら、closestream)を行う。

  13. bodybodystream: stream, source: source, length: length)を設定する。

  14. (body, type) を返す。

5.3. Bodyミックスイン

interface mixin Body {
  readonly attribute ReadableStream? body;
  readonly attribute boolean bodyUsed;
  [NewObject] Promise<ArrayBuffer> arrayBuffer();
  [NewObject] Promise<Blob> blob();
  [NewObject] Promise<Uint8Array> bytes();
  [NewObject] Promise<FormData> formData();
  [NewObject] Promise<any> json();
  [NewObject] Promise<USVString> text();
};

ネットワーク層が依存してほしくない形式、例えばHTMLなどはここで公開されることはありません。そうした形式は、将来的にHTMLパーサAPIがストリームを受け入れるようになる可能性があります。

Bodyインターフェースミックスインを含むオブジェクトは、関連付けられたbody(nullまたはbody)を持ちます。

Body インターフェースミックスインを含むオブジェクトは、 その body が null でなく、 かつその bodystream乱された または ロック済み の場合、 使用不可 であると言う。


requestOrResponse . body

requestOrResponseのbodyをReadableStreamとして返します。

requestOrResponse . bodyUsed

requestOrResponseのbodyが既に読み取られたかどうかを返します。

requestOrResponse . arrayBuffer()

requestOrResponseのbodyをArrayBufferとして返すPromiseを返します。

requestOrResponse . blob()

requestOrResponseのbodyをBlobとして返すPromiseを返します。

requestOrResponse . bytes()

requestOrResponseのbodyをUint8Arrayとして返すPromiseを返します。

requestOrResponse . formData()

requestOrResponseのbodyをFormDataとして返すPromiseを返します。

requestOrResponse . json()

requestOrResponseのbodyをJSONとしてパースした結果を返すPromiseを返します。

requestOrResponse . text()

requestOrResponseのbodyを文字列として返すPromiseを返します。


MIMEタイプ取得は、RequestまたはResponseオブジェクトrequestOrResponseに対して以下を実行します:

  1. headersをnullに設定する。

  2. requestOrResponseRequestオブジェクトなら、headersrequestOrResponserequestheader listを設定する。

  3. それ以外の場合、headersrequestOrResponseresponseheader listを設定する。

  4. mimeTypeMIMEタイプ抽出headers)の結果を設定する。

  5. mimeTypeが失敗ならnullを返す。

  6. mimeTypeを返す。

bodygetterの手順は、thisbodyがnullならnullを返し、そうでなければthisbodystreamを返すこと。

bodyUsedgetterの手順は、thisbodyがnullでなく、かつthisbodystreamdisturbedならtrue、そうでなければfalseを返すこと。

consume body アルゴリズムは、Bodyを含むオブジェクトobjectと、バイト列を受け取りJavaScript値を返す(または例外を投げる)アルゴリズムconvertBytesToJSValueを受け取り、以下を実行します:

  1. object使用不可なら、TypeErrorでrejectされたpromiseを返す。

  2. promise新しいpromiseを設定する。

  3. errorStepserror)にpromiseerrorrejectする手順を設定する。
  4. successStepsバイト列data)にpromiseconvertBytesToJSValuedata)の結果でresolveする手順(例外ならerrorStepsを実行)を設定する。
  5. objectbodyがnullなら、空のバイト列successStepsを実行する。

  6. それ以外なら、完全に読み取るobjectbodysuccessStepserrorStepsobject関連グローバルオブジェクト)を実行する。

  7. promiseを返す。

arrayBuffer() メソッドのステップは、consume bodythis で実行し、次のステップで指定される バイト列 bytes を受け取った場合: thisrelevant realmbytes から ArrayBuffer を生成する処理の結果を返す。

上記のメソッドは RangeError によりリジェクトされる場合がある。

blob() メソッドのステップは、consume bodythis で実行し、次のステップで指定される バイト列 bytes を受け取った場合:内容が bytes であり、その type 属性が this で MIME タイプを取得 した結果である Blob を返す。

bytes() メソッドのステップは、consume bodythis で実行し、次のステップで指定される バイト列 bytes を受け取った場合: thisrelevant realmbytes から Uint8Array を生成する処理の結果を返す。

上記のメソッドは RangeError によりリジェクトされる場合がある。

formData() メソッドのステップは、consume bodythis で実行し、次のステップで指定される バイト列 bytes を受け取った場合:

  1. mimeTypethis で MIME タイプを取得 した結果とする。

  2. mimeType が null でなければ、その mimeTypeエッセンス により次の処理に分岐して実行:

    "multipart/form-data"
    1. bytesmimeType の `boundary` パラメータ値を用いて Returning Values from Forms: multipart/form-data にしたがってパースする。 [RFC7578]

      `Content-Disposition` ヘッダーに `filename` パラメータが含まれる各パートは、 その内容を値とし entry にパースする。その値は内容であり、 File オブジェクトとして生成される。 name 属性はそのパートの `filename` パラメータの値とし、 type 属性はそのパートの `Content-Type` ヘッダーの値(ヘッダーがなければ `text/plain`)にする。

      `Content-Disposition` ヘッダーに `filename` パラメータが 含まれない各パートは、その内容を UTF-8(BOMなしで)でデコードして entry にパースする。 これは `Content-Type` ヘッダーや `charset` パラメータの有無や値にかかわらず行われる。

      `Content-Disposition` ヘッダーの `name` パラメータ値が `_charset_` であっても 他と同様にパースされ、エンコーディングの変更にはならない。

    2. なんらかの理由で失敗した場合は TypeError をスローする。

    3. パース結果のすべての entryentry list に追加して 新しい FormData オブジェクトを返す。

    上記は `multipart/form-data` 向けの大まかな記述であり、 より詳細なパース仕様は今後記載される予定。 ボランティア歓迎。

    "application/x-www-form-urlencoded"
    1. entries を、bytes をパースした結果とする。

    2. entriesentry list とした 新しい FormData オブジェクトを返す。

  3. TypeError をスローする。

json() メソッドのステップは、consume bodythis で実行し、 bytes から JSON をパース する。

上記メソッドは SyntaxError でリジェクトされる場合がある。

text() メソッドのステップは、consume bodythis で実行し、 UTF-8 デコード する。

5.4. Requestクラス

typedef (Request or USVString) RequestInfo;

[Exposed=(Window,Worker)]
interface Request {
  constructor(RequestInfo input, optional RequestInit init = {});

  readonly attribute ByteString method;
  readonly attribute USVString url;
  [SameObject] readonly attribute Headers headers;

  readonly attribute RequestDestination destination;
  readonly attribute USVString referrer;
  readonly attribute ReferrerPolicy referrerPolicy;
  readonly attribute RequestMode mode;
  readonly attribute RequestCredentials credentials;
  readonly attribute RequestCache cache;
  readonly attribute RequestRedirect redirect;
  readonly attribute DOMString integrity;
  readonly attribute boolean keepalive;
  readonly attribute boolean isReloadNavigation;
  readonly attribute boolean isHistoryNavigation;
  readonly attribute AbortSignal signal;
  readonly attribute RequestDuplex duplex;

  [NewObject] Request clone();
};
Request includes Body;

dictionary RequestInit {
  ByteString method;
  HeadersInit headers;
  BodyInit? body;
  USVString referrer;
  ReferrerPolicy referrerPolicy;
  RequestMode mode;
  RequestCredentials credentials;
  RequestCache cache;
  RequestRedirect redirect;
  DOMString integrity;
  boolean keepalive;
  AbortSignal? signal;
  RequestDuplex duplex;
  RequestPriority priority;
  any window; // can only be set to null
};

enum RequestDestination { "", "audio", "audioworklet", "document", "embed", "font", "frame", "iframe", "image", "json", "manifest", "object", "paintworklet", "report", "script", "sharedworker", "style",  "track", "video", "worker", "xslt" };
enum RequestMode { "navigate", "same-origin", "no-cors", "cors" };
enum RequestCredentials { "omit", "same-origin", "include" };
enum RequestCache { "default", "no-store", "reload", "no-cache", "force-cache", "only-if-cached" };
enum RequestRedirect { "follow", "error", "manual" };
enum RequestDuplex { "half" };
enum RequestPriority { "high", "low", "auto" };

"serviceworker" は、 RequestDestination から省略されています。なぜなら、これは JavaScript から観測できないためです。実装は、destination としてサポートする必要がありますが、"websocket" および "webtransport" は、RequestMode から省略されています。なぜなら、これらも JavaScript から使用または観測することができないためです。

Requestオブジェクトには関連付けられたrequestrequest)があります。

Requestオブジェクトには、関連付けられたheaders(nullまたはHeadersオブジェクト、初期値はnull)があります。

Requestオブジェクトには、関連付けられたsignal(nullまたはAbortSignalオブジェクト、初期値はnull)があります。

Requestオブジェクトのbodyは、そのrequestbodyです。


request = new Request(input [, init])

新しい request を返します。その url プロパティは、 input が文字列の場合は inputinputRequest オブジェクトの場合は その url となります。

init 引数は、以下のようなプロパティを持つオブジェクトです:

method
requestmethod を設定する文字列。
headers
Headers オブジェクト、オブジェクトリテラル、または2要素配列の配列で requestheaders を設定。
body
BodyInit オブジェクトまたは null を指定して requestbody を設定。
referrer
同一オリジンのURL、"about:client"、または空文字列を指定し、requestreferrer を設定。
referrerPolicy
referrer policy を指定し、requestreferrerPolicy を設定。
mode
CORS を使うか同一オリジンURLに限定するかを示す文字列を指定。 requestmode を設定。 input が文字列の場合はデフォルトで "cors" です。
credentials
クレデンシャルを常に/絶対に送信しない/同一オリジン時のみ送信するか(またレスポンスで受信したクレデンシャルを使うか)を示す文字列を指定。 requestcredentials を設定。 input が文字列の場合はデフォルトで "same-origin" です。
cache
フェッチ時にリクエストがブラウザキャッシュとどう連携するかを示す文字列で requestcache を設定。
redirect
リダイレクトを追随するか・エラーとするか・不透明で返すかを示す文字列で requestredirect を設定。
integrity
request で取得するリソースの暗号学的ハッシュ値を指定し、requestintegrity を設定。
keepalive
真偽値で requestkeepalive を設定。
signal
AbortSignal を指定して requestsignal を設定。
window
null のみ指定可。request を任意の Window から切り離す用途。
duplex
"half" のみ有効で、ハーフデュプレックス(リクエスト全体を送信後にレスポンスを処理)フェッチを行うための値。 "full" は将来のフルデュプレックスフェッチ用途で予約済み(リクエスト送信中にもレスポンス処理可)。 bodyReadableStream の場合はこれを指定。 "full" の定義は issue #1254 参照。
priority
requestpriority を設定する文字列。
request . method
request の HTTP メソッドを返します。デフォルトは "GET" です。
request . url
request の URL を文字列で返します。
request . headers
request に紐づく Headers オブジェクトを返します。 ユーザーエージェントがネットワーク層で追加するヘッダー(例:"Host" ヘッダーなど)はこのオブジェクトには含まれません。
request . destination
request が要求するリソース種別を返します(例:"document" や "script")。
request . referrer
request のリファラーを返します。 値は init で明示的に設定した同一オリジンURL、リファラーなしの場合は空文字列、デフォルト時は "about:client" となります。 これはフェッチ実行時の Referer ヘッダー値決定に用いられます。
request . referrerPolicy
request に紐付けられた referrer policy を返します。フェッチ時のリファラー計算に使用されます。
request . mode
request に紐付けられた mode を返します。CORS 利用有無や同一オリジン限定かを示す文字列です。
request . credentials
request に紐付けられた credentials mode を返します。クレデンシャル送信有無・条件を表す文字列です。
request . cache
requestcache mode を返します。フェッチ時のキャッシュ連携方法を示す文字列です。
request . redirect
requestredirect mode を返します。リダイレクト時の扱いを示します。デフォルトでリダイレクトを追従します。
request . integrity
request のサブリソースインテグリティ(取得リソースの暗号学的ハッシュ値)を返します。 値はスペース区切りで複数のハッシュを持つことがあります。[SRI]
request . keepalive
request が作成元のグローバルより長生きできるかどうかの真偽値を返します。
request . isReloadNavigation
request がリロードナビゲーション用か否かの真偽値を返します。
request . isHistoryNavigation
request が履歴ナビゲーション用か(いわゆる戻る/進む)かの真偽値を返します。
request . signal
request に紐付けられた AbortSignal オブジェクトを返し、それに abort 済みか、および abort イベントハンドラも含みます。
request . duplex
"half" を返します。これは「ハーフデュプレックス」(リクエスト全体を先に送り、その後レスポンスを処理)であることを示します。 将来は "full"(リクエスト送信中にレスポンス処理可能)も返し得ます。"full" の定義は issue #1254 参照。
request . clone()

request のクローンを返します。


Requestオブジェクトの作成は、Request オブジェクトを、request requestheaders guard guardAbortSignal オブジェクトsignalrealm realmを指定して次の手順で作成します:

  1. requestObjectrealm新しいRequestオブジェクトを生成する。

  2. requestObjectrequestrequestに設定する。

  3. requestObjectheadersを、realm新しいHeadersオブジェクト(headers listrequestheaders listguardguard)に設定する。

  4. requestObjectsignalsignalに設定する。

  5. requestObjectを返す。


new Request(input, init) コンストラクタの手順は次の通りです:

  1. requestをnullに設定する。

  2. fallbackModeをnullに設定する。

  3. baseURLthisrelevant settings objectAPI base URLを設定する。

  4. signalをnullに設定する。

  5. inputが文字列なら:

    1. parsedURLinputbaseURLパースした結果を設定する。

    2. parsedURLが失敗ならTypeError例外を投げる。

    3. parsedURL認証情報を含むならTypeError例外を投げる。

    4. requestrequestURLparsedURL)を新規作成して設定する。

    5. fallbackModeを"cors"に設定する。

  6. それ以外の場合:

    1. アサートinputRequestオブジェクトであること。

    2. requestinputrequestを設定する。

    3. signalinputsignalを設定する。

  7. originthisrelevant settings objectoriginを設定する。

  8. traversableForUserPromptsを"client"に設定する。

  9. requesttraversable for user promptsenvironment settings objectであり、そのoriginorigin同一オリジンなら、traversableForUserPromptsrequesttraversable for user promptsに設定する。

  10. init["window"]が存在し、nullでなければTypeError例外を投げる。

  11. init["window"]が存在すれば、traversableForUserPromptsを"no-traversable"に設定する。

  12. requestに次のプロパティでrequestを新規作成して設定する:

    URL
    requestURL
    method
    requestmethod
    header list
    requestheader listのコピー
    unsafe-request flag
    セットする
    client
    thisrelevant settings object
    traversable for user prompts
    traversableForUserPrompts
    internal priority
    requestinternal priority
    origin
    requestoriginオリジンの伝播はサービスワーカーによるナビゲーションリクエスト処理時のみ重要です。この場合リクエストのオリジンが現在のクライアントと異なることがあります。
    referrer
    requestreferrer
    referrer policy
    requestreferrer policy
    mode
    requestmode
    credentials mode
    requestcredentials mode
    cache mode
    requestcache mode
    redirect mode
    requestredirect mode
    integrity metadata
    requestintegrity metadata
    keepalive
    requestkeepalive
    reload-navigation flag
    requestreload-navigation flag
    history-navigation flag
    requesthistory-navigation flag
    URL list
    requestURL listクローン
    initiator type
    "fetch"
  13. init空でない場合:

    1. requestmodeが"navigate"なら、"same-origin"に設定する。

    2. requestreload-navigation flagを解除する。

    3. requesthistory-navigation flagを解除する。

    4. requestoriginを"client"に設定する。

    5. requestreferrerを"client"に設定する。

    6. requestreferrer policyを空文字列に設定する。

    7. requestURLrequestcurrent URLに設定する。

    8. requestURL listを« requestURL »に設定する。

    サービスワーカーがクロスオリジンスタイルシート中の画像等からリダイレクトしてリクエストを書き換える場合、もはや元のソース(クロスオリジンスタイルシート)から来たようには見えず、リダイレクトしたサービスワーカーから来たと扱われる。元ソースが同種リクエストを生成できない場合があるため、これが重要。元ソースを信頼するサービスが攻撃される恐れもある(稀だが)。

  14. init["referrer"]が存在する場合:

    1. referrerinit["referrer"]を設定する。

    2. referrerが空文字列なら、requestreferrerを"no-referrer"に設定する。

    3. それ以外の場合:

      1. parsedReferrerreferrerbaseURLパースした結果を設定する。

      2. parsedReferrerが失敗ならTypeError例外を投げる。

      3. 次のいずれかが成立する場合

        なら、requestreferrerを"client"に設定する。

      4. それ以外の場合、requestreferrerparsedReferrerに設定する。

  15. init["referrerPolicy"]が存在すれば、requestreferrer policyをその値に設定する。

  16. modeinit["mode"]が存在するならその値、しなければfallbackModeを設定する。

  17. modeが"navigate"ならTypeError例外を投げる。

  18. modeがnullでなければ、requestmodemodeに設定する。

  19. init["credentials"]が存在すれば、requestcredentials modeをその値に設定する。

  20. init["cache"]が存在すれば、requestcache modeをその値に設定する。

  21. requestcache modeが"only-if-cached"かつmodeが"same-origin"でなければTypeError例外を投げる。

  22. init["redirect"]が存在すれば、requestredirect modeをその値に設定する。

  23. init["integrity"]が存在すれば、requestintegrity metadataをその値に設定する。

  24. init["keepalive"]が存在すれば、requestkeepaliveをその値に設定する。

  25. init["method"]が存在すれば:

    1. methodinit["method"]を設定する。

    2. methodmethodでない、またはmethod禁止メソッドならTypeError例外を投げる。

    3. method正規化する。

    4. requestmethodmethodに設定する。

  26. init["signal"]が存在すれば、signalをその値に設定する。

  27. init["priority"]が存在すれば:

    1. requestinternal priorityがnullでなければ、実装定義の方法でinternal priorityを更新する。

    2. それ以外の場合、requestpriorityinit["priority"]に設定する。

  28. thisrequestrequestに設定する。

  29. signalssignalがnullでなければ« signal »、そうでなければ« »を設定する。

  30. thissignaldependent abort signalの作成signalsAbortSignalthisrelevant realm)の結果に設定する。

  31. thisheaders新しいHeadersオブジェクト(thisrelevant realm、header listはrequestheader list、guardは"request")に設定する。

  32. thisrequestmodeが"no-cors"なら:

    1. thisrequestmethodCORS安全リストメソッドでなければTypeError例外を投げる。

    2. thisheadersguardを"request-no-cors"に設定する。

  33. init空でない場合:

    このモードで許可されないヘッダーが含まれる可能性があるためヘッダーをサニタイズする。そうでなければ、以前にサニタイズ済みか特権APIで設定され変更されていない。

    1. headersthisheadersと関連header listのコピーを設定する。

    2. init["headers"]が存在すれば、headersinit["headers"]に設定する。

    3. thisheadersheader listを空にする。

    4. headersHeadersオブジェクトなら、header(header listの要素)について、append(header)をthisheadersに実行する。

    5. それ以外の場合、fillthisheadersheaders)を実行する。

  34. inputBodyinputRequestオブジェクトならinputrequestbody、それ以外ならnullを設定する。

  35. init["body"]が存在しかつnullでない、またはinputBodyがnullでない場合で、requestmethodが`GET`または`HEAD`ならTypeError例外を投げる。

  36. initBodyをnullに設定する。

  37. init["body"]が存在しかつnullでない場合:

    1. bodyWithTypeextractinit["body"]、keepaliverequestkeepalive)の結果を設定する。

    2. initBodybodyWithTypebodyを設定する。

    3. typebodyWithTypetypeを設定する。

    4. typeがnullでなく、thisheadersheader listが`Content-Type`を含まない場合、append(`Content-Type`、type)をthisheadersに実行する。

  38. inputOrInitBodyinitBodyがnullでなければそれを、そうでなければinputBodyを設定する。

  39. inputOrInitBodyがnullでなく、そのsourceがnullなら:

    1. もし initBody が null でなく、かつ init["duplex"] が 存在しない場合、TypeError を投げる。

    2. もし thisrequestmode が "same-origin" または "cors" でない場合、TypeError を投げる。

    3. thisrequestuse-CORS-preflight flagをセットする。

  40. finalBodyinputOrInitBodyを設定する。

  41. initBodyがnullかつinputBodyがnullでない場合:

    1. もし inputBody使用不可 なら、throwTypeError を投げる。

    2. finalBodyproxyの生成 の結果(inputBody を対象)を設定する。

  42. thisrequestbodyfinalBodyに設定する。

methodゲッターの手順は、thisrequestmethodを返すこと。

urlゲッターの手順は、thisrequestURL直列化して返すこと。

headersゲッターの手順は、thisheadersを返すこと。

destinationゲッターの手順は、thisrequestdestinationを返すこと。

referrerゲッターの手順は次の通りです:

  1. thisrequestreferrerが"no-referrer"なら空文字列を返す。

  2. thisrequestreferrerが"client"なら"about:client"を返す。

  3. thisrequestreferrer直列化して返す。

referrerPolicyゲッターの手順は、thisrequestreferrer policyを返すこと。

modeゲッターの手順は、thisrequestmodeを返すこと。

credentialsゲッターの手順は、thisrequestcredentials modeを返すこと。

cacheゲッターの手順は、thisrequestcache modeを返すこと。

redirectゲッターの手順は、thisrequestredirect modeを返すこと。

integrityゲッターの手順は、thisrequestintegrity metadataを返すこと。

keepaliveゲッターの手順は、thisrequestkeepaliveを返すこと。

isReloadNavigationゲッターの手順は、thisrequestreload-navigation flagがセットされていればtrue、そうでなければfalseを返すこと。

isHistoryNavigationゲッターの手順は、thisrequesthistory-navigation flagがセットされていればtrue、そうでなければfalseを返すこと。

signalゲッターの手順は、thissignalを返すこと。

Thissignalは常に constructor内および cloning時に初期化されます。

duplexゲッターの手順は"half"を返すこと。


clone() メソッドの手順は以下の通りです:

  1. thisunusable の場合は、throwTypeError を投げる。

  2. clonedRequestcloning thisrequest から得る。

  3. Assert: thissignal は null ではない。

  4. clonedSignal を « thissignal » から dependent abort signal を作成することにより取得する。使用するのは AbortSignalthisrelevant realm である。

  5. clonedRequestObjectcreating より Request オブジェクトとして生成する。与える値は clonedRequest, thisheadersguard, clonedSignal, そして thisrelevant realm である。

  6. clonedRequestObject を返す。

5.5. Responseクラス

[Exposed=(Window,Worker)]
interface Response {
  constructor(optional BodyInit? body = null, optional ResponseInit init = {});

  [NewObject] static Response error();
  [NewObject] static Response redirect(USVString url, optional unsigned short status = 302);
  [NewObject] static Response json(any data, optional ResponseInit init = {});

  readonly attribute ResponseType type;

  readonly attribute USVString url;
  readonly attribute boolean redirected;
  readonly attribute unsigned short status;
  readonly attribute boolean ok;
  readonly attribute ByteString statusText;
  [SameObject] readonly attribute Headers headers;

  [NewObject] Response clone();
};
Response includes Body;

dictionary ResponseInit {
  unsigned short status = 200;
  ByteString statusText = "";
  HeadersInit headers;
};

enum ResponseType { "basic", "cors", "default", "error", "opaque", "opaqueredirect" };

Response オブジェクトには関連付けられたresponseresponse)があります。

Response オブジェクトには、関連付けられたheaders(nullまたはHeadersオブジェクト、初期値はnull)があります。

Response オブジェクトのbodyは、そのresponsebodyです。


response = new Response(body = null [, init])

Responseオブジェクトを生成し、bodyはbody、status・status message・headersはinitで指定されます。

response = Response . error()

ネットワークエラーのResponseオブジェクトを生成します。

response = Response . redirect(url, status = 302)

urlstatusでリダイレクトするResponseを生成します。

response = Response . json(data [, init])

bodyがJSONエンコードされたdata、status・status message・headersはinitで指定されるResponseを生成します。

response . type

responseのtype(例:"cors")を返します。

response . url

responseにURLがあれば返し、なければ空文字列を返します。

response . redirected

responseがリダイレクトによって取得されたかどうかを返します。

response . status

responseのstatusを返します。

response . ok

responseのstatusがok statusならtrueを返します。

response . statusText

responseのstatus messageを返します。

response . headers

responseのheadersをHeadersとして返します。

response . clone()

responseのクローンを返します。


作成するには、Response オブジェクト、response responseheaders guard guardrealm realm を受け取って以下を実行する:

  1. responseObject新しい Response オブジェクト(realm付き)とする。

  2. responseObjectresponseresponse に設定する。

  3. responseObjectheaders新しい Headers オブジェクト(realm付き)で、headers listresponseheaders listguardguardに設定する。

  4. responseObject を返す。

レスポンスを初期化するには、 Response オブジェクト responseResponseInit init、 null または 型付きbody body を与えて、次の手順を行う:

  1. もし init["status"] が 200 以上 599 以下の範囲外であれば、 RangeError をスローする。

  2. もし init["statusText"] が空文字列でなく、かつ reason-phrase トークン生成規則に一致しない場合、 TypeError をスローする。

  3. responseresponsestatusinit["status"] に設定する。

  4. responseresponsestatus messageinit["statusText"] に設定する。

  5. もし init["headers"] が 存在するなら、 fill responseheadersinit["headers"] で満たす。

  6. もし body が null でなければ:

    1. もし responsestatusnull body status なら TypeError をスローする。

      101および103は他の用途のため null body status に含まれるが、 これはこの手順には影響しない。

    2. responsebodybodybody に設定する。

    3. もし bodytype が null でなく、 かつ responseheader list`Content-Type`を含まない場合、 append (`Content-Type`、bodytype)を responseheader list に追加する。


new Response(body, init) コンストラクターの手順は以下の通りです:

  1. thisresponse を新しい response に設定する。

  2. thisheadersnew Headers オブジェクト(thisrelevant realmを持ち、 header listthisresponseheader listguardは "response" )に設定する。

  3. bodyWithType を null にする。

  4. body が null でない場合、bodyWithTypeextracting body の結果に設定する。

  5. initialize a responsethis, init, bodyWithType を与えて実行する。

静的 error() メソッドの手順は、 新しい network error、 "immutable"、 current realm を与えて 作成した Response オブジェクトを返すこと。

静的 redirect(url, status) メソッドの手順は:

  1. parsedURLパースurlcurrent settings objectAPI base URL を使って取得する。

  2. parsedURL が failure なら TypeError をスローする。

  3. statusredirect status でなければ RangeError をスローする。

  4. responseObject を、新しい response、「immutable」、および current realm を与えて Response オブジェクトをResponseとして作成 create した結果とする。

  5. responseObjectresponsestatusstatus に設定する。

  6. valueparsedURLシリアライズおよび 等形エンコードした結果とする。

  7. append (`Location`, value) を responseObjectresponseheader list に追加する。

  8. responseObject を返す。

静的 json(data, init) メソッドの手順は:

  1. bytesJavaScript値をJSONバイト列へシリアライズdata を処理した結果とする。

  2. bodyextracting bytes の結果とする。

  3. responseObject作成で新しい response、"response"、current realm を与えて生成する。

  4. レスポンスの初期化responseObjectinit、(body, "application/json") で実行する。

  5. responseObject を返す。

type の getter の手順は、thisresponsetype を返すことである。

url の getter の手順は、thisresponseURL が null なら空文字列を返す。 それ以外の場合は thisresponseURLserialize し、exclude fragment を true に設定して返す。

redirected の getter の手順は、 thisresponseURL listsize が 1 より大きければ true、そうでなければ false を返すことである。

リダイレクトの結果となる response を除外したい場合は、API を直接使って、 例えば fetch(url, { redirect:"error" }) のようにする。 この方法であれば、潜在的に安全でない response が誤って漏洩することがなくなる。

status の getter の手順は、 thisresponsestatus を返すことである。

ok の getter の手順は、 thisresponsestatusok status なら true、それ以外は false を返す。

statusText の getter の手順は、 thisresponsestatus message を返すことである。

headers の getter の手順は、 thisheaders を返すことである。


clone() メソッドの手順は以下の通りである:

  1. thisunusable なら、throwTypeError を投げる。

  2. clonedResponsecloning thisresponse から取得する。

  3. creating を使って Response オブジェクトを生成し、 clonedResponse, thisheadersguardthisrelevant realm を与えて返す。

5.6. Fetchメソッド

partial interface mixin WindowOrWorkerGlobalScope {
  [NewObject] Promise<Response> fetch(RequestInfo input, optional RequestInit init = {});
};

dictionary DeferredRequestInit : RequestInit {
  DOMHighResTimeStamp activateAfter;
};

[Exposed=Window]
interface FetchLaterResult {
  readonly attribute boolean activated;
};

partial interface Window {
  [NewObject, SecureContext] FetchLaterResult fetchLater(RequestInfo input, optional DeferredRequestInit init = {});
};

fetch(input, init) メソッドの手順は以下の通りです:

  1. p新しい promise とする。

  2. requestObjectRequest の初期値をコンストラクターとして inputinit を引数にして呼び出した結果とする。例外が投げられた場合は、 reject p でその例外を渡し、p を返す。

  3. requestrequestObjectrequest とする。

  4. もし requestObjectsignalabort されている なら、以下を実行する:

    1. fetch() 呼び出しを中止する。引数は p, request, null, そして requestObjectsignalabort reason

    2. p を返す。

  5. globalObjectrequestclientglobal object とする。
  6. globalObjectServiceWorkerGlobalScope オブジェクトなら、requestservice-workers mode を "none" に設定する。

  7. responseObject を null とする。

  8. relevantRealmthisrelevant realm とする。

  9. locallyAborted を false とする。

    これにより、abort のリクエストが fetch の呼び出し元と同じスレッドから来た場合、promise を予測可能なタイミングで reject できるようになる。

  10. controller を null とする。

  11. 以下の abort 手順を追加する。追加先は requestObjectsignal:

    1. locallyAborted を true に設定する。

    2. Assert: controller は null でない。

    3. Abort controller。引数は requestObjectsignalabort reason

    4. fetch() 呼び出しを中止する。引数は p, request, responseObject, そして requestObjectsignalabort reason

  12. controllerfetch の呼び出し結果とする。引数は requestprocessResponseresponse には以下の手順を与える:

    1. locallyAborted が true なら、これ以降の手順を中止する。

    2. responseaborted flag が設定されていたら、以下を実行:

      1. deserializedErrorserialize された abort reason をデシリアライズする。引数は controllerserialized abort reasonrelevantRealm

      2. fetch() 呼び出しを中止する。引数は p, request, responseObject, deserializedError

      3. これ以降の手順を中止する。

    3. responsenetwork error なら、reject pTypeError を与えて、これ以降の手順を中止する。

    4. responseObjectcreatingResponse オブジェクトとして生成する。引数は response, "immutable", relevantRealm

    5. resolve presponseObject を与える。

  13. p を返す。

fetch() 呼び出しを中止する ためには、promiserequestresponseObjecterror を受け取って以下を実行する:

  1. promiseerror で拒否する。

    すでに promise が解決済みの場合は何もしない(no-op)。

  2. もし requestbody が non-null かつ readable なら、 cancelrequestbodyerror でキャンセルする。

  3. responseObject が null なら return する。

  4. responseresponseObjectresponse とする。

  5. もし responsebody が non-null かつ readable なら、 errorresponsebodyerror でエラー化する。

FetchLaterResultには関連付けられたactivated getter steps(booleanを返すアルゴリズム)があります。

activated の getter の手順は、 thisactivated getter steps を実行した結果を返すことである。

fetchLater(input, init) メソッドの手順は以下の通りである:

  1. requestObjectRequest の初期値をコンストラクターとして input および init を引数に呼び出した結果とする。

  2. requestObjectsignalaborted である場合は、 signalabort reason をスローする。

  3. requestrequestObjectrequest とする。

  4. activateAfter を null とする。

  5. もし init が与えられ、かつ init["activateAfter"] 存在する 場合、activateAfterinit["activateAfter"] を設定する。

  6. activateAfter が 0 未満の場合、RangeError をスローする。

  7. thisrelevant global objectassociated documentfully active でない場合、 TypeError をスローする。

  8. requestURLschemeHTTP(S) scheme でない場合、 TypeError をスローする。

  9. requestURLpotentially trustworthy URL でない場合、 TypeError をスローする。

  10. requestbody が null でなく、かつ requestbodylength が null の場合、 TypeError をスローする。

    bodyReadableStream オブジェクトであるリクエストは遅延できない。

  11. quota利用可能な deferred-fetch クォータrequestclient および requestURLorigin を与えたもの)とする。

  12. requestedrequesttotal request length とする。

  13. quotarequested より小さい場合、 スロー する QuotaExceededErrorquotaquota かつ requestedrequested

  14. activated を false とする。

  15. deferredRecord遅延フェッチをキューするrequest, activateAfter, そして次のステップ(activated を true に設定)を渡して呼び出した結果とする。

  16. 次の中断処理requestObjectsignal に追加する: deferredRecordinvoke state を "aborted" に設定する。

  17. 新しい FetchLaterResult を返す。 その activated getter stepsactivated を返すこととする。

次の呼び出しは、ドキュメントが終了したときにフェッチされるリクエストをキューします:

fetchLater("https://report.example.com", {
  method: "POST",
  body: JSON.stringify(myReport),
  headers: { "Content-Type": "application/json" }
})

次の呼び出しは5秒後にこのリクエストをキューし、返された値で本当にアクティベートされたかどうか確認できます。ユーザーエージェントがタイマーをスロットルしても、リクエストは必ず実行されます。

const result = fetchLater("https://report.example.com", {
  method: "POST",
  body: JSON.stringify(myReport),
  headers: { "Content-Type": "application/json" },
  activateAfter: 5000
});

function check_if_fetched() {
  return result.activated;
}

FetchLaterResultオブジェクトはAbortSignalと組み合わせて使うこともできます。例えば:

let accumulated_events = [];
let previous_result = null;
const abort_signal = new AbortSignal();
function accumulate_event(event) {
  if (previous_result) {
    if (previous_result.activated) {
      // リクエストは既にアクティベートされているので、新しく始められます。
      accumulated_events = [];
    } else {
      // このリクエストをabortして、すべてのイベントで新規リクエストを開始します。
      signal.abort();
    }
  }

  accumulated_events.push(event);
  result = fetchLater("https://report.example.com", {
    method: "POST",
    body: JSON.stringify(accumulated_events),
    headers: { "Content-Type": "application/json" },
    activateAfter: 5000,
    abort_signal
  });
}

以下のいずれかのfetchLater()呼び出しは例外が投げられます:

// potentially trustworthy URLのみサポート
fetchLater("http://untrusted.example.com");

// deferredリクエストの長さは事前に分かっている必要があります。
fetchLater("https://origin.example.com", {body: someDynamicStream});

// deferred fetchはactiveなwindowでのみ動作します。
const detachedWindow = iframe.contentWindow;
iframe.remove();
detachedWindow.fetchLater("https://origin.example.com");

deferred fetch quotaの例も参照。

5.7. ガベージコレクション

ユーザーエージェントは、スクリプトから観測できない場合、進行中のfetchを終了してもよい。

「スクリプトから観測できる」とは、fetch() の引数と戻り値で観測できることを意味します。それ以外の方法(サーバーとのサイドチャネル通信など)は含みません。

サーバーがガベージコレクションを観測できる例は既に存在します。例えば WebSocketXMLHttpRequest オブジェクトなどです。

ユーザーエージェントは、終了が観測できないためfetchを終了できる。

fetch("https://www.example.com/")

ユーザーエージェントは、promise経由で終了が観測できるためfetchを終了できない。

window.promise = fetch("https://www.example.com/")

関連するbodyが観測できないため、ユーザーエージェントはfetchを終了できる。

window.promise = fetch("https://www.example.com/").then(res => res.headers)

終了が観測できないため、ユーザーエージェントはfetchを終了できる。

fetch("https://www.example.com/").then(res => res.body.getReader().closed)

promiseオブジェクトにハンドラを登録することで、終了が観測できるためユーザーエージェントはfetchを終了できない。

window.promise = fetch("https://www.example.com/")
  .then(res => res.body.getReader().closed)

登録されたハンドラで終了が観測できるため、ユーザーエージェントはfetchを終了できない。

fetch("https://www.example.com/")
  .then(res => {
    res.body.getReader().closed.then(() => console.log("stream closed!"))
  })

(上記の非観測性の例は、組み込みプロパティや関数(body.getReader()など)が上書きされていないことを前提としています。)

6. data: URL

data: URL についての参考情報は RFC 2397 を参照のこと。この節は、実際にデプロイ済みのコンテンツとの互換性を保つために、同 RFC の規範的な処理要件を置き換える。[RFC2397]

data: URL 構造体とは、以下からなる構造体である: MIME タイプMIME タイプ)、および bodyバイト列)。

data: URL処理は、URL dataURL を受け取り、次の手順を実行する:

  1. アサートdataURLスキーム は "data" である。

  2. input を、URLシリアライザdataURL に対し、フラグメント除外 を true 指定で実行した結果とする。

  3. input から先頭の "data:" を取り除く。

  4. positioninput の先頭を指すようにする。

  5. mimeType を、U+002C(,)でないコードポイントの連続position から収集したものとする。

  6. mimeType の前後の ASCII 空白 を取り除く。

    ここで削除されるのは、U+0020 SPACE コードポイント のみである。

  7. positioninput の末尾を超えていたら、失敗を返す。

  8. position を1だけ進める。

  9. encodedBodyinput の残り全体とする。

  10. bodyencodedBody のパーセントデコード とする。

  11. もし mimeType が U+003B(;)で終わり、続けて0個以上のU+0020 SPACE、その後に "base64"(ASCII大文字小文字無視で判定)があれば、以下を行う:

    1. stringBodybody のアイソモーフィックデコード とする。

    2. bodystringBody の forgiving-base64 decode の結果にする。

    3. body が失敗なら、失敗を返す。

    4. mimeType の末尾6つのコードポイント を削除する。

    5. mimeType 末尾から U+0020 SPACE コードポイント を(もしあれば)取り除く。

    6. mimeType 末尾の U+003B(;)を一つ取り除く。

  12. もし mimeType が ";" で始まるなら、"text/plain" を先頭に付加する。

  13. mimeTypeRecordmimeType のパース 結果とする。

  14. mimeTypeRecord が失敗なら、 text/plain;charset=US-ASCII に設定する。

  15. data: URL 構造体を生成して返す。MIME タイプは mimeTypeRecord、bodyは body。

参考文献

このセクションおよびその下位セクションは参考情報のみです。

HTTPヘッダー階層の区分

fetchにおいては、API層(HTMLのimg、CSSのbackground-image)、早期fetch層、Service Worker層、ネットワーク&キャッシュ層があります。`Accept`や`Accept-Language`は早期fetch層(通常はユーザーエージェントが設定)で扱われます。他のほとんどのユーザーエージェント制御ヘッダー(`Accept-Encoding`、`Host`、`Referer`など)はネットワーク&キャッシュ層で設定されます。開発者はAPI層またはService Worker層(通常はRequestオブジェクト経由)でヘッダーを設定できます。 禁止リクエストヘッダーはほぼ制御できませんが、`Accept`は制御でき、例えば`Referer`は省略・制限できます。

HTTPリダイレクトのアトミックな取り扱い

リダイレクト(responsestatus または internal response(もしあれば)の statusリダイレクトステータスの場合)は、APIに公開されません。 リダイレクトを公開すると、クロスサイトスクリプティング攻撃などでは取得できない情報が漏れる可能性があります。

例えばhttps://example.org/authに対するfetchで、HttpOnly付きのCookieが含まれている場合、https://other-origin.invalid/4af955781ea1c84a3b11にリダイレクトされる可能性があります。この新しいURLには秘密情報が含まれています。リダイレクトを公開すれば、その秘密がクロスサイトスクリプティング攻撃で取得されてしまいます。

CORSプロトコルの安全な基本設定

IP認証やファイアウォールによってデータが保護されているリソース(残念ながら現在も比較的多い)では、CORSプロトコルの使用は安全ではありません。(このためCORSプロトコルが考案されました。)

しかし、下記のようなヘッダーの使用は安全です:

Access-Control-Allow-Origin: *

リソースがCookieやHTTP認証で追加情報を公開している場合でも、上記のヘッダーを使ってもそれが漏れることはありません。API(XMLHttpRequestなど)にリソースを共有できます。 これはcurlwgetと同様です。

言い換えれば、リソースがWeb上の任意のデバイスからcurlwgetでアクセスできない場合、上記のヘッダーは含めるべきではありません。アクセスできる場合は問題ありません。

CORSプロトコルとHTTPキャッシュ

CORSプロトコルの要件が`Access-Control-Allow-Origin`を*や静的なoriginに設定するだけより複雑な場合は、`Vary`を使う必要があります。[HTML] [HTTP] [HTTP-CACHING]

Vary: Origin

特に、`Vary`が使われず、サーバーが特定のリソースに対しAccess-Control-Allow-Origin`をCORSリクエストにのみ返す場合を考えてください。ユーザーエージェントが非CORSリクエスト(例えばナビゲーションリクエスト)でそのリソースのレスポンスを受け取った場合、そのレスポンスには`Access-Control-Allow-Origin`が含まれず、ユーザーエージェントはそのレスポンスをキャッシュします。その後ユーザーエージェントが同じリソースに対してCORSリクエストを発行すると、以前の非CORSリクエストのキャッシュレスポンスが使われ、`Access-Control-Allow-Origin`がない状態になります。

しかし、同じ状況で`Vary: Origin`を使えば、ユーザーエージェントは`Access-Control-Allow-Origin`を含むレスポンスをfetchし、以前の非CORSリクエストのキャッシュレスポンスは使われません。

一方、特定のリソースについて`Access-Control-Allow-Origin`を*や静的なoriginに設定している場合は、サーバーは常にそのリソースのレスポンスで`Access-Control-Allow-Origin`を返し、非CORSリクエストでもCORSリクエストでも同様にし、`Vary`は使わないようにします。

WebSocket

接続を確立する過程で、WebSocket オブジェクトは特殊な種類の フェッチrequestmode が "websocket" であるリクエストを使う)を開始します。これにより、多くのフェッチポリシーの判断(例えば HTTP Strict Transport Security (HSTS) など)を共有できます。最終的に、フェッチは WebSockets に呼び出され、専用の接続を取得することになります。[WEBSOCKETS] [HSTS]

フェッチは以前、WebSocket の接続を取得するWebSocket 接続を確立する を直接定義していましたが、現在はどちらも WebSockets で定義されています。[WEBSOCKETS]

他の標準での fetch の利用

本質的に フェッチrequestresponse の交換です。実際には、標準で正しく採用・利用するにはかなり複雑な仕組みです。この節ではそのための助言を提供します。

必ずドメインの専門家にレビューを依頼してください。

この仕様は作業中です。

リクエストの準備

フェッチの最初のステップは、 リクエストを作成し、 その各項目を埋めることです。

最初にリクエストURLメソッドを、 HTTP の定義に従って設定します。`POST`や`PUT`のリクエストで 本文が必要な場合は、リクエストbodyバイト列または新しい ボディstream が あなたが作成した ReadableStream であるもの)を 設定します。[HTTP]

リクエストdestinationdestination の表の指針で選んでください。destinationContent Security Policy に影響し、 `Sec-Fetch-Dest` ヘッダーなどにも影響するため、単なるメタデータ以上の意味があります。 新機能で表にないdestinationが必要な場合は、 issue で相談してください。[CSP]

リクエストclient は、 操作中の environment settings object にしてください。 Web に公開される API は通常 Web IDL で定義されており、全ての インターフェース 実装オブジェクトは対応する settings objectを持ちます。 例えば、リクエストが ある要素と関連づく場合は、 その要素のリクエストclient を その要素のnode documentrelevant settings objectに設定します。 JavaScript、HTML、CSS などから直接ウェブで利用される全ての Document のサブリソース機能には client が必要です。

フェッチが直接Webで公開されていない場合、 例えば現在の WindowWorker に依存せずバックグラウンド送信の場合は、 リクエストclientは null のままにして、 リクエストoriginpolicy containerservice-workers modereferrer などを それぞれ適切な値(例:事前にコピーしておいた environment settings object のもの)に設定してください。 このような応用的なケースでは、フェッチがContent Security Policy および referrer policy をどのように扱うか を必ず明記してください。また、コールバック(Invoking fetch and processing responses を参照)は parallel queue で行われるため並行処理も確実にハンドルしてください。 [REFERRER][CSP]

クロスオリジンリソースの扱いに注意してください。機能が同一オリジン限定でのみ動作する場合は、 リクエストmodeに "same-origin" を設定します。 そうでなければ新しい Web 公開機能では 基本的に mode を "cors" に設定します。Web 非公開の機能や CORS なしでクロスオリジンリソース取得が必要な場合は issue で相談してください。

クロスオリジンリクエストの場合、クレデンシャル を含めるかどうかも決めなければなりません。含める場合は リクエストcredentials modeを "include" に設定します。

そのフェッチがResource Timingに報告される必要があるか、またどの イニシエータ種別で 報告されるべきかを決めてください。イニシエータ種別リクエストに渡すことで、フェッチ完了および レスポンスの完全なダウンロード完了時に Resource Timingへの報告が自動的に行われます。[RESOURCE-TIMING]

リクエストに追加の HTTP ヘッダーが必要な場合は、header list にそれらを含む ヘッダーリストを設定してください。 例えば « (`My-Header-Name`, `My-Header-Value`) » のようにします。 カスタムヘッダーを送信する場合、CORS プレフライトフェッチ が必要となるなどの影響があるので注意してください。

デフォルトのキャッシュ機構を上書き(たとえばこのリクエストでキャッシュを無効化)したい場合は、 リクエストのcache modeを"default"以外の値に設定します。

リクエストでリダイレクトをサポートするかどうかも決めてください。不要なら、 redirect modeを"error"に設定します。

リクエストの残りのパラメータについても、 必要があれば確認してください。これらは利用頻度が低く、特殊な目的で使われることが多いですが、 この標準の§ 2.2.5 Requestsで詳細に説明されています。

fetch の呼び出しとレスポンス処理

リクエスト以外に、 fetch操作にはいくつかの オプション引数を指定できます。アルゴリズムを受け取る引数については、そのアルゴリズムは タスクから(または parallel queueuseParallelQueue 真なら parallel queue で)呼び出されます。

リクエストの準備ができたら、fetchにどのアルゴリズムを渡すかは、 レスポンスをどのような段階でどのように扱いたいかを考えます。 特にコールバックをどの段階で受け取りたいかを決定します。

完了時

ほとんどの呼び出し者はこの方法でレスポンスを扱います。例えばスクリプトスタイルリソース等です。 レスポンスボディ はすべてバイト列へ読み込まれ、その後呼び出し元によって処理されます。

完了時にレスポンスを処理するには、 そのアルゴリズムを processResponseConsumeBody 引数としてfetchに渡します。 与えるアルゴリズムには、responseと、レスポンスの body が完全に読まれた値を表す引数が渡されます。 (そのresponse内部レスポンスに属します)。 2番目の引数が取り得る値は以下の通りです:

null
レスポンスbodyが null の場合。 ネットワークエラーやnull ボディステータスによる。
failure
完全に読み取ることを試みたが、例えば I/O エラーなどにより、レスポンスボディの内容の読み取りに失敗した。
バイト列

レスポンス内部レスポンスbody完全読取に成功した。

リクエストのmodeが"no-cors"の場合でも 全内容のバイト列が渡されるので注意。 そのようなコンテンツの扱いには注意が必要で(呼び出し元オリジンで直接可視になってはならない)、 例として`no-cors`レスポンスの内容を直接ユーザーに表示することはあっても、 その内容を埋め込み側スクリプトで直接操作すべきではありません。

  1. URLがhttps://stuff.example.com/で、clientthisrelevant settings objectであるrequestとする。

  2. Fetch request(下記のステップを processResponseConsumeBody に設定)の例。 応答responseおよびnull/failureまたは バイト列contentsを受け取る:

    1. contents が null か failure ならエラーをユーザーに提示

    2. そうでなければ contents を response のメタデータを考慮してパースして処理

ヘッダー+逐次チャンク処理

例えば動画再生や画像の逐次ロードなど、チャンクごとにレスポンスをストリームとして 処理したい場合などは呼び出し元でヘッダー受信直後から順次処理が始まります。 response はヘッダー処理後にユーザーに渡り、以降はユーザーが続きを扱います。

チャンク毎にresponseを処理するには、 processResponse引数へ アルゴリズムを指定してfetchします。 引数にはレスポンスヘッダー受信時点で responseが渡され、 レスポンス本体の bodystream をユーザー自身で読み込んで処理します。 また便利のため、応答全体の読取が終わったタイミングで呼び出せる processResponseEndOfBodyアルゴリズムも別で渡せます。 (ただし processResponseConsumeBody と違い ここで指定してもユーザーが読取りを必ず行う保証はありません)

processResponse 引数は、 responseヘッダーリストstatus のみをみてボディを一切処理しない場合にも利用できます。 たとえば status が ok status でない場合の処理に用いられます。

  1. URLがhttps://stream.example.com/で、clientthisrelevant settings objectである requestとする。

  2. Fetch request(下記のアルゴリズムを processResponseに設定)例。 応答responseを受け取る:

    1. response が ネットワークエラーならユーザーにエラー提示

    2. そうでなく、かつ status がok statusでなければフォールバック値を提示

    3. それ以外の場合は, readerで response の bodystreamを取得し、 responseのヘッダーからMIME typeを判定して適切に処理

レスポンス無視

場合によってはresponse自体が不要なこともあります。 たとえば navigator.sendBeacon() などです。レスポンス処理およびコールバック渡しは任意であり、 コールバックを省略すれば応答を期待しない fetch になります。その場合、responsebodystream は破棄され、呼び出し元は不要なダウンロードを心配しなくて済みます。

Fetch URLがhttps://fire-and-forget.example.com/メソッドPOSTclientthisrelevant settings objectである requestの例。

レスポンスハンドリング用コールバック以外にも、fetchはより高度なケース向けの追加コールバックも受け付けます。 processEarlyHintsResponseは statusが103のresponse 専用で現在はナビゲーションのみが用います。 processRequestBodyChunkLengthprocessRequestEndOfBodyは リクエストボディアップロード進捗の通知用途です。

fetch操作は呼出元と同じスレッドで開始し、 内部処理自体は並列で動作します。上記コールバックは指定されたイベントループ (デフォルトでclientglobal object)に ポストされます。レスポンスを自ら並列で処理しメインスレッドとのやり取りをハンドルしたい場合は fetchuseParallelQueueをtrueにして使ってください。

進行中の fetch の操作

すでに開始された fetch 操作を操作するには、 fetch 呼び出しで返される fetch controller を使います。例えば、ユーザーやページのロジックで abort したり、 ブラウザ内部の事情で terminate することができます。

terminate や abort 以外にも、タイミングの報告initiator type を渡していない場合の報告、 完全なタイミング情報の取得(ナビゲーションのみ)なども可能です。 fetch controller次の手動リダイレクトの処理にも使われます( requestredirect mode が "manual" の場合)。

謝辞

感謝を表します: Adam Barth、 Adam Lavin、 Alan Jeffrey、 Alexey Proskuryakov、 Andreas Kling、 Andrés Gutiérrez、 Andrew Sutherland、 Andrew Williams、 Ángel González、 Anssi Kostiainen、 Arkadiusz Michalski、 Arne Johannessen、 Artem Skoretskiy、 Arthur Barstow、 Arthur Sonzogni、 Asanka Herath、 Axel Rauschmayer、 Ben Kelly、 Benjamin Gruenbaum、 Benjamin Hawkes-Lewis、 Benjamin VanderSloot、 Bert Bos、 Björn Höhrmann、 Boris Zbarsky、 Brad Hill、 Brad Porter、 Bryan Smith、 Caitlin Potter、 Cameron McCormack、 Carlo Cannas、 白丞祐 (Cheng-You Bai)、 Chirag S Kumar、 Chris Needham、 Chris Rebert、 Clement Pellerin、 Collin Jackson、 Daniel Robertson、 Daniel Veditz、 Dave Tapuska、 David Benjamin、 David Håsäther、 David Orchard、 Dean Jackson、 Devdatta Akhawe、 Domenic Denicola、 Dominic Farolino、 Dominique Hazaël-Massieux、 Doug Turner、 Douglas Creager、 Eero Häkkinen、 Ehsan Akhgari、 Emily Stark、 Eric Lawrence、 Eric Orth、 Feng Yu、 François Marier、 Frank Ellerman、 Frederick Hirsch、 Frederik Braun、 Gary Blackwood、 Gavin Carothers、 Glenn Maynard、 Graham Klyne、 Gregory Terzian、 Guohui Deng(邓国辉)、 Hal Lockhart、 Hallvord R. M. Steen、 Harris Hancock、 Henri Sivonen、 Henry Story、 Hiroshige Hayashizaki、 Honza Bambas、 Ian Hickson、 Ilya Grigorik、 isonmad、 Jake Archibald、 James Graham、 Jamie Mansfield、 Janusz Majnert、 Jeena Lee、 Jeff Carpenter、 Jeff Hodges、 Jeffrey Yasskin、 Jensen Chappell、 Jeremy Roman、 Jesse M. Heines、 Jianjun Chen、 Jinho Bang、 Jochen Eisinger、 John Wilander、 Jonas Sicking、 Jonathan Kingston、 Jonathan Watt、 최종찬 (Jongchan Choi)、 Jordan Stephens、 Jörn Zaefferer、 Joseph Pecoraro、 Josh Matthews、 jub0bs、 Julian Krispel-Samsel、 Julian Reschke、 송정기 (Jungkee Song)、 Jussi Kalliokoski、 Jxck、 Kagami Sascha Rosylight、 Keita Suzuki、 Keith Yeung、 Kenji Baheux、 Lachlan Hunt、 Larry Masinter、 Liam Brummitt、 Linus Groh、 Louis Ryan、 Luca Casonato、 Lucas Gonze、 Łukasz Anforowicz、 呂康豪 (Kang-Hao Lu)、 Maciej Stachowiak、 Malisa、 Manfred Stock、 Manish Goregaokar、 Marc Silbey、 Marcos Caceres、 Marijn Kruisselbrink、 Mark Nottingham、 Mark S. Miller、 Martin Dürst、 Martin O’Neal、 Martin Thomson、 Matt Andrews、 Matt Falkenhagen、 Matt Menke、 Matt Oshry、 Matt Seddon、 Matt Womer、 Mhano Harkness、 Michael Ficarra、 Michael Kohler、 Michael™ Smith、 Mike Pennisi、 Mike West、 Mohamed Zergaoui、 Mohammed Zubair Ahmed、 Moritz Kneilmann、 Ms2ger、 Nico Schlömer、 Nicolás Peña Moreno、 Nidhi Jaju、 Nikhil Marathe、 Nikki Bee、 Nikunj Mehta、 Noam Rosenthal、 Odin Hørthe Omdal、 Olli Pettay、 Ondřej Žára、 O. Opsec、 Patrick Meenan、 Perry Jiang、 Philip Jägenstedt、 R. Auburn、 Raphael Kubo da Costa、 Robert Linder、 Rondinelly、 Rory Hewitt、 Ross A. Baker、 Ryan Sleevi、 Sam Atkins、 Samy Kamkar、 Sébastien Cevey、 Sendil Kumar N、 Shao-xuan Kang、 Sharath Udupa、 Shivakumar Jagalur Matt、 Shivani Sharma、 Sigbjørn Finne、 Simon Pieters、 Simon Sapin、 Simon Wülker、 Srirama Chandra Sekhar Mogali、 Stephan Paul、 Steven Salat、 Sunava Dutta、 Surya Ismail、 Tab Atkins-Bittner、 Takashi Toyoshima、 吉野剛史 (Takeshi Yoshino)、 Thomas Roessler、 Thomas Steiner、 Thomas Wisniewski、 Tiancheng "Timothy" Gu、 Tobie Langel、 Tom Schuster、 Tomás Aparicio、 triple-underscore、 保呂毅 (Tsuyoshi Horo)、 Tyler Close、 Ujjwal Sharma、 Vignesh Shanmugam、 Vladimir Dzhuvinov、 Wayne Carr、 Xabier Rodríguez、 Yehuda Katz、 Yoav Weiss、 Yoshisato Yanagisawa、 Youenn Fablet、 Yoichi Osato、 平野裕 (Yutaka Hirano)、 Zhenbin Xu 素晴らしい協力に感謝します。

本現行標準は Anne van Kesteren (Apple, annevk@annevk.nl) によって執筆されています。

知的財産権

Copyright © WHATWG (Apple, Google, Mozilla, Microsoft)。この成果物は Creative Commons Attribution 4.0 International License に基づきライセンスされています。ソースコードに組み込まれる部分については、BSD 3-Clause License に基づきライセンスされます。

これは現行標準です。 特許審査版に関心がある場合は 現行標準レビュー草案を参照してください。

索引

この仕様で定義されている用語

参照で定義される用語

参考文献

規範的参考文献

[ABNF]
D. Crocker, Ed.; P. Overell. 構文仕様のための拡張BNF:ABNF。2008年1月。Internet Standard。URL: https://www.rfc-editor.org/rfc/rfc5234
[BEACON]
Ilya Grigorik; Alois Reitbauer. Beacon。URL: https://w3c.github.io/beacon/
[COOKIES]
Johann Hofmann; Anne van Kesteren. Cookies: HTTP 状態管理メカニズム。URL: https://httpwg.org/http-extensions/draft-ietf-httpbis-layered-cookies.html
[CSP]
Mike West; Antonio Sartori. Content Security Policy Level 3。URL: https://w3c.github.io/webappsec-csp/
[CSS-VALUES-4]
Tab Atkins Jr.; Elika Etemad. CSS Values and Units Module Level 4。URL: https://drafts.csswg.org/css-values-4/
[DOM]
Anne van Kesteren. DOM標準。現行標準。URL: https://dom.spec.whatwg.org/
[ECMASCRIPT]
ECMAScript言語仕様。URL: https://tc39.es/ecma262/multipage/
[ENCODING]
Anne van Kesteren. Encoding標準。現行標準。URL: https://encoding.spec.whatwg.org/
[FETCH-METADATA]
Mike West. Fetch Metadataリクエストヘッダー。URL: https://w3c.github.io/webappsec-fetch-metadata/
[FILEAPI]
Marijn Kruisselbrink. File API。URL: https://w3c.github.io/FileAPI/
[HR-TIME-3]
Yoav Weiss. 高分解能時間。URL: https://w3c.github.io/hr-time/
[HSTS]
J. Hodges; C. Jackson; A. Barth. HTTP Strict Transport Security (HSTS)。2012年11月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc6797
[HTML]
Anne van Kesteren; et al. HTML標準。現行標準。URL: https://html.spec.whatwg.org/multipage/
[HTTP]
R. Fielding, Ed.; M. Nottingham, Ed.; J. Reschke, Ed.. HTTPセマンティクス。2022年6月。Internet Standard。URL: https://httpwg.org/specs/rfc9110.html
[HTTP-CACHING]
R. Fielding, Ed.; M. Nottingham, Ed.; J. Reschke, Ed.. HTTPキャッシュ。2022年6月。Internet Standard。URL: https://httpwg.org/specs/rfc9111.html
[HTTP1]
R. Fielding, Ed.; M. Nottingham, Ed.; J. Reschke, Ed.. HTTP/1.1。2022年6月。Internet Standard。URL: https://httpwg.org/specs/rfc9112.html
[HTTP3]
M. Bishop, Ed.. HTTP/3。2022年6月。提案標準。URL: https://httpwg.org/specs/rfc9114.html
[HTTP3-DATAGRAM]
D. Schinazi; L. Pardue. HTTP DatagramとCapsuleプロトコル。2022年8月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc9297
[IANA-HTTP-PARAMS]
ハイパーテキスト転送プロトコル (HTTP) パラメータ。URL: https://www.iana.org/assignments/http-parameters/http-parameters.xhtml
[INFRA]
Anne van Kesteren; Domenic Denicola. Infra 標準。現行標準。URL: https://infra.spec.whatwg.org/
[MIMESNIFF]
Gordon P. Hemsley. MIME Sniffing標準。現行標準。URL: https://mimesniff.spec.whatwg.org/
[MIX]
Emily Stark; Mike West; Carlos IbarraLopez. Mixed Content。URL: https://w3c.github.io/webappsec-mixed-content/
[PERMISSIONS-POLICY-1]
Ian Clelland. Permissions Policy。URL: https://w3c.github.io/webappsec-permissions-policy/
[REFERRER]
Jochen Eisinger; Emily Stark. Referrer Policy。URL: https://w3c.github.io/webappsec-referrer-policy/
[REPORTING]
Douglas Creager; Ian Clelland; Mike West. Reporting API。URL: https://w3c.github.io/reporting/
[RESOURCE-TIMING]
Yoav Weiss; Noam Rosenthal. Resource Timing。URL: https://w3c.github.io/resource-timing/
[RFC7405]
P. Kyzivat. ABNFにおける大文字小文字区別文字列サポート。2014年12月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc7405
[RFC7578]
L. Masinter. フォームからの値返却:multipart/form-data。2015年7月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc7578
[RFC9218]
K. Oku; L. Pardue. HTTPの拡張優先順位付け方式。2022年6月。提案標準。URL: https://httpwg.org/specs/rfc9218.html
[RFC9651]
M. Nottingham; P-H. Kamp. HTTPの構造化フィールド値。2024年9月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc9651
[SECURE-CONTEXTS]
Mike West. Secure Contexts。URL: https://w3c.github.io/webappsec-secure-contexts/
[SRI]
Frederik Braun. Subresource Integrity。URL: https://w3c.github.io/webappsec-subresource-integrity/
[STALE-WHILE-REVALIDATE]
M. Nottingham. HTTPのキャッシュ制御拡張:Stale Content。2010年5月。Informational。URL: https://httpwg.org/specs/rfc5861.html
[STREAMS]
Adam Rice; et al. Streams標準。現行標準。URL: https://streams.spec.whatwg.org/
[SVCB]
B. Schwartz; M. Bishop; E. Nygren. DNSによるService Bindingとパラメータ指定 (SVCBとHTTPS Resource Record)。2023年11月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc9460
[SW]
Monica CHINTALA; Yoshisato Yanagisawa. Service Workers Nightly. URL: https://w3c.github.io/ServiceWorker/
[TLS]
E. Rescorla. Transport Layer Security (TLS) プロトコル バージョン1.3。2018年8月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc8446
[UPGRADE-INSECURE-REQUESTS]
Mike West. Upgrade Insecure Requests。URL: https://w3c.github.io/webappsec-upgrade-insecure-requests/
[URL]
Anne van Kesteren. URL標準。現行標準。URL: https://url.spec.whatwg.org/
[WEBDRIVER-BIDI]
James Graham; Alex Rudenko; Maksim Sadym. WebDriver BiDi. URL: https://w3c.github.io/webdriver-bidi/
[WEBIDL]
Edgar Chen; Timothy Gu. Web IDL標準。現行標準。URL: https://webidl.spec.whatwg.org/
[WEBSOCKETS]
Adam Rice. WebSockets標準。現行標準。URL: https://websockets.spec.whatwg.org/
[WEBTRANSPORT]
Nidhi Jaju; Victor Vasiliev; Jan-Ivar Bruaroey. WebTransport. URL: https://w3c.github.io/webtransport/
[WEBTRANSPORT-HTTP3]
V. Vasiliev. WebTransport over HTTP/3。URL: https://datatracker.ietf.org/doc/html/draft-ietf-webtrans-http3
[XHR]
Anne van Kesteren. XMLHttpRequest標準。現行標準。URL: https://xhr.spec.whatwg.org/

参考情報文献

[HTTPVERBSEC1]
複数ベンダーのWebサーバーではHTTP TRACEメソッドがデフォルトで有効化されています。。URL: https://www.kb.cert.org/vuls/id/867593
[HTTPVERBSEC2]
Microsoft Internet Information Server (IIS)はHTTP TRACKメソッド経由でクロスサイトスクリプティングの脆弱性があります。。URL: https://www.kb.cert.org/vuls/id/288308
[HTTPVERBSEC3]
HTTPプロキシのデフォルト設定により任意のTCP接続が許可されます。。URL: https://www.kb.cert.org/vuls/id/150227
[NAVIGATION-TIMING]
Zhiheng Wang. ナビゲーションタイミング。2012年12月17日。REC。URL: https://www.w3.org/TR/navigation-timing/
[ORIGIN]
A. Barth. WebのOrigin概念。2011年12月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc6454
[RFC1035]
P. Mockapetris. ドメイン名 - 実装と仕様。1987年11月。Internet Standard。URL: https://www.rfc-editor.org/rfc/rfc1035
[RFC2397]
L. Masinter. "data" URLスキーム。1998年8月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc2397
[RFC6960]
S. Santesson; 他. X.509インターネット公開鍵基盤オンライン証明書ステータスプロトコル - OCSP。2013年6月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc6960
[RFC7301]
S. Friedl; 他. Transport Layer Security (TLS) アプリケーション層プロトコルネゴシエーション拡張。2014年7月。提案標準。URL: https://www.rfc-editor.org/rfc/rfc7301
[RFC7918]
A. Langley; N. Modadugu; B. Moeller. Transport Layer Security (TLS) False Start。2016年8月。Informational。URL: https://www.rfc-editor.org/rfc/rfc7918
[RFC8470]
M. Thomson; M. Nottingham; W. Tarreau. HTTPにおけるEarly Dataの利用。2018年9月。提案標準。URL: https://httpwg.org/specs/rfc8470.html
[RFC9163]
E. Stark. HTTP用Expect-CT拡張。2022年6月。実験的。URL: https://www.rfc-editor.org/rfc/rfc9163

IDL索引

typedef (sequence<sequence<ByteString>> or record<ByteString, ByteString>) HeadersInit;

[Exposed=(Window,Worker)]
interface Headers {
  constructor(optional HeadersInit init);

  undefined append(ByteString name, ByteString value);
  undefined delete(ByteString name);
  ByteString? get(ByteString name);
  sequence<ByteString> getSetCookie();
  boolean has(ByteString name);
  undefined set(ByteString name, ByteString value);
  iterable<ByteString, ByteString>;
};

typedef (Blob or BufferSource or FormData or URLSearchParams or USVString) XMLHttpRequestBodyInit;

typedef (ReadableStream or XMLHttpRequestBodyInit) BodyInit;
interface mixin Body {
  readonly attribute ReadableStream? body;
  readonly attribute boolean bodyUsed;
  [NewObject] Promise<ArrayBuffer> arrayBuffer();
  [NewObject] Promise<Blob> blob();
  [NewObject] Promise<Uint8Array> bytes();
  [NewObject] Promise<FormData> formData();
  [NewObject] Promise<any> json();
  [NewObject] Promise<USVString> text();
};
typedef (Request or USVString) RequestInfo;

[Exposed=(Window,Worker)]
interface Request {
  constructor(RequestInfo input, optional RequestInit init = {});

  readonly attribute ByteString method;
  readonly attribute USVString url;
  [SameObject] readonly attribute Headers headers;

  readonly attribute RequestDestination destination;
  readonly attribute USVString referrer;
  readonly attribute ReferrerPolicy referrerPolicy;
  readonly attribute RequestMode mode;
  readonly attribute RequestCredentials credentials;
  readonly attribute RequestCache cache;
  readonly attribute RequestRedirect redirect;
  readonly attribute DOMString integrity;
  readonly attribute boolean keepalive;
  readonly attribute boolean isReloadNavigation;
  readonly attribute boolean isHistoryNavigation;
  readonly attribute AbortSignal signal;
  readonly attribute RequestDuplex duplex;

  [NewObject] Request clone();
};
Request includes Body;

dictionary RequestInit {
  ByteString method;
  HeadersInit headers;
  BodyInit? body;
  USVString referrer;
  ReferrerPolicy referrerPolicy;
  RequestMode mode;
  RequestCredentials credentials;
  RequestCache cache;
  RequestRedirect redirect;
  DOMString integrity;
  boolean keepalive;
  AbortSignal? signal;
  RequestDuplex duplex;
  RequestPriority priority;
  any window; // can only be set to null
};

enum RequestDestination { "", "audio", "audioworklet", "document", "embed", "font", "frame", "iframe", "image", "json", "manifest", "object", "paintworklet", "report", "script", "sharedworker", "style",  "track", "video", "worker", "xslt" };
enum RequestMode { "navigate", "same-origin", "no-cors", "cors" };
enum RequestCredentials { "omit", "same-origin", "include" };
enum RequestCache { "default", "no-store", "reload", "no-cache", "force-cache", "only-if-cached" };
enum RequestRedirect { "follow", "error", "manual" };
enum RequestDuplex { "half" };
enum RequestPriority { "high", "low", "auto" };

[Exposed=(Window,Worker)]
interface Response {
  constructor(optional BodyInit? body = null, optional ResponseInit init = {});

  [NewObject] static Response error();
  [NewObject] static Response redirect(USVString url, optional unsigned short status = 302);
  [NewObject] static Response json(any data, optional ResponseInit init = {});

  readonly attribute ResponseType type;

  readonly attribute USVString url;
  readonly attribute boolean redirected;
  readonly attribute unsigned short status;
  readonly attribute boolean ok;
  readonly attribute ByteString statusText;
  [SameObject] readonly attribute Headers headers;

  [NewObject] Response clone();
};
Response includes Body;

dictionary ResponseInit {
  unsigned short status = 200;
  ByteString statusText = "";
  HeadersInit headers;
};

enum ResponseType { "basic", "cors", "default", "error", "opaque", "opaqueredirect" };

partial interface mixin WindowOrWorkerGlobalScope {
  [NewObject] Promise<Response> fetch(RequestInfo input, optional RequestInit init = {});
};

dictionary DeferredRequestInit : RequestInit {
  DOMHighResTimeStamp activateAfter;
};

[Exposed=Window]
interface FetchLaterResult {
  readonly attribute boolean activated;
};

partial interface Window {
  [NewObject, SecureContext] FetchLaterResult fetchLater(RequestInfo input, optional DeferredRequestInit init = {});
};

MDN

Headers/Headers

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/append

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/delete

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/get

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/getSetCookie

In all current engines.

Firefox112+Safari17+Chrome113+
Opera?Edge113+
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js19.7.0+
MDN

Headers/has

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/set

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Request/Request

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera27+Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile27+
MDN

Request/arrayBuffer

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/arrayBuffer

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/blob

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/blob

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/body

FirefoxNoneSafari11.1+Chrome105+
Opera?Edge105+
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/body

In all current engines.

Firefox65+Safari10.1+Chrome43+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/bodyUsed

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/bodyUsed

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/cache

In all current engines.

Firefox48+Safari10.1+Chrome64+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/clone

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/credentials

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/destination

In all current engines.

Firefox61+Safari10.1+Chrome65+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/formData

In all current engines.

Firefox39+Safari14.1+Chrome60+
Opera?Edge79+
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/formData

In all current engines.

Firefox39+Safari14.1+Chrome60+
Opera?Edge79+
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/headers

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/integrity

In all current engines.

Firefox51+Safari10.1+Chrome46+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/json

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/json

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/method

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/mode

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/redirect

In all current engines.

Firefox43+Safari10.1+Chrome46+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/referrer

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/referrerPolicy

In all current engines.

Firefox47+Safari10.1+Chrome52+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet7.2+Opera Mobile?
MDN

Request/signal

In all current engines.

Firefox57+Safari12.1+Chrome66+
Opera?Edge79+
Edge (Legacy)16+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/text

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?

Response/text

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Request/url

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile27+
MDN

Request

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Response/Response

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/clone

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/error_static

In all current engines.

Firefox39+Safari10.1+Chrome43+
Opera?Edge79+
Edge (Legacy)16+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/headers

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/json_static

Firefox115+SafariNoneChrome105+
Opera?Edge105+
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/ok

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/redirect_static

In all current engines.

Firefox39+Safari10.1+Chrome44+
Opera?Edge79+
Edge (Legacy)16+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/redirected

In all current engines.

Firefox49+Safari10.1+Chrome57+
Opera?Edge79+
Edge (Legacy)16+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView60+Samsung Internet8.0+Opera Mobile?
MDN

Response/status

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/statusText

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/type

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response/url

In all current engines.

Firefox39+Safari10.1+Chrome40+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Response

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

fetch

In all current engines.

Firefox39+Safari10.1+Chrome42+
Opera?Edge79+
Edge (Legacy)14+IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
Node.js18.0.0+
MDN

Headers/Access-Control-Allow-Credentials

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Allow-Headers

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Allow-Methods

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Allow-Origin

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Expose-Headers

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Max-Age

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Request-Headers

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Access-Control-Request-Method

In all current engines.

Firefox3.5+Safari4+Chrome4+
Opera12+Edge79+
Edge (Legacy)12+IE10+
Firefox for Android?iOS Safari?Chrome for AndroidYesAndroid WebView2+Samsung Internet?Opera Mobile12+
MDN

Headers/Cross-Origin-Resource-Policy

In all current engines.

Firefox74+Safari12+Chrome73+
OperaNoneEdge79+
Edge (Legacy)NoneIENone
Firefox for AndroidNoneiOS Safari?Chrome for Android?Android WebView?Samsung Internet11.0+Opera MobileNone
MDN

Headers/Origin

In all current engines.

Firefox70+SafariYesChromeYes
Opera?EdgeYes
Edge (Legacy)12+IEYes
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera Mobile?
MDN

Headers/Sec-Purpose

In only one current engine.

Firefox115+SafariNoneChromeNone
Opera?EdgeNone
Edge (Legacy)?IENone
Firefox for Android?iOS Safari?Chrome for Android?Android WebView?Samsung Internet?Opera MobileNone
MDN

Headers/X-Content-Type-Options

In all current engines.

Firefox50+Safari11+Chrome64+
OperaYesEdge79+
Edge (Legacy)12+IE8+
Firefox for Android?iOS Safari?Chrome for Android64+Android WebView?Samsung Internet?Opera MobileYes