AI Dev Lab
Web本番障害シミュレーター

CORS エラーの切り分けを訓練するための確認順

CORS エラーが出たときに、ブラウザ側、API 側、設定差分のどこから見るかを incident-sim の訓練導線に沿ってまとめた記事です。

·decision主力·stage公開中

CORS エラーの切り分けを訓練するための確認順

CORS エラーは、見た目は似ていても原因が何通りもあります。
フロント側の呼び出しなのか、API 側の許可設定なのか、環境差分なのかを、短時間で切り分けられるかが重要です。

このページでは、incident-sim で練習するときに意識したい確認順をまとめます。

最初に分けるべき三つ

まずは次の三つを分けて考えます。

  1. ブラウザからのリクエスト自体は飛んでいるか
  2. API 側はレスポンスを返しているか
  3. 許可ヘッダーやオリジン設定が想定どおりか

ここを混ぜると、原因特定が遅くなります。

よくある確認ポイント

  • Origin が想定のドメインになっているか
  • Access-Control-Allow-Origin が不足していないか
  • OPTIONS が失敗していないか
  • ステージングと本番で許可設定が違っていないか
  • API Gateway や CDN 側でヘッダーが消えていないか

訓練で見るべきログ

incident-sim でこのテーマを扱うなら、次を往復できるようにしたいです。

  • ブラウザのエラー表示
  • ネットワークタブのリクエスト内容
  • API 側のアクセスログ
  • 直前デプロイの設定差分

実務で効くのは確認順

CORS の知識そのものより、どこから見るかの順番が大事です。

  • 先にブラウザだけ見て終わらない
  • API だけ疑ってフロント条件を見落とさない
  • 設定変更の履歴を最初から候補に入れる

この順番が安定すると、初動のスピードが上がります。

次に進むなら

  • incident-sim の CORS 系シナリオで手を動かす
  • 環境変数ミスガイドと見比べて、設定系障害の共通点を整理する
  • 結果画面で「最初に見た場所」が妥当だったかを振り返る

読むだけだと身につきにくいテーマなので、練習導線まで使う前提で見るのがおすすめです。

[ ./next_action ]

読んだら、 Web本番障害シミュレーター を実際に動かす。

この開発ログは Web本番障害シミュレーター をどう作ったかの記録です。 読み終わったらそのままサービス本体へ戻って、 実物で価値を確かめてください。

[ ./related_logs ]

関連する開発ログ

all logs →
ToonCast

ToonCast ができるまで — AnimeGANv2 をブラウザで動かす

AnimeGANv2 の小さな ONNX (約9MB) を onnxruntime-web (単一スレッド WASM=COOP/COEP不要、 color-revive で承認済みライブラリの再利用) で実行。 512x512・[-1,1] 正規化で推論し、 結果を元解像度に戻して表示する設計記録。 写真は端末内処理。

read log →
ColorRevive

ColorRevive ができるまで — onnxruntime-web で白黒写真をカラー化

DeOldify の量子化 ONNX を onnxruntime-web (CDN side-load・単一スレッド WASM=COOP/COEP不要) で実行。 256x256 でモデル推論し、 輝度は元写真・色だけ AI を YCbCr で再合成して輪郭を保つ設計記録。 写真は端末内処理。

read log →
PhotoTwin

PhotoTwin ができるまで — CLIP画像埋め込みで似た写真を見つける

CLIP (Xenova/clip-vit-base-patch32) の image-feature-extraction を transformers.js の CDN ESM で side-load し、 各写真を正規化ベクトル化。 cosine 類似度で重複・似た写真をブラウザ内で検出する設計記録 (新ライブラリ追加なし=what-cam と同じ CLIP の再利用)。

read log →
AkinFind

AkinFind ができるまで — 文章embeddingsで意味検索をブラウザ内に

多言語の文章埋め込みモデル (Xenova/multilingual-e5-small) を transformers.js の CDN ESM で side-load し、 各文を正規化ベクトル化。 cosine 類似度で意味検索と似ている文ペア検出を全て端末内で行う設計記録。

read log →
WhatCam

WhatCam ができるまで — CLIP のゼロショット画像分類をブラウザで動かす

CLIP (Xenova/clip-vit-base-patch32) を transformers.js の CDN ESM で side-load し、 写真と候補ラベルの近さをブラウザ内で計算。 日本語ラベルを英語プロンプトに変換し、 図鑑と自由入力の両モードで「これ何?」を判定する設計記録。

read log →
DepthCast

DepthCast ができるまで — 1枚の写真をAIの深度推定で立体にする

Depth Anything (transformers.js) を CDN ESM で side-load し、 1枚の写真から深度マップを推定。 WebGL2 フラグメントシェーダで深度に比例した視差 (iterative backward parallax) を作り、 赤青アナグリフ / WebM 書き出しまで端末内で完結させた設計記録。

read log →