415エラー(Unsupported Media Type)とは
415エラーは、HTTPステータスコードの一種です。クライアントが送信したリクエストのメディアタイプを、サーバーが処理できない場合に返されるエラーです。このエラーは主に、APIやWebアプリケーションでデータを送信する際に、Content-Typeヘッダーの指定が不適切であったり、サーバー側が対応していない形式のデータを送信した際に発生します。
正式名称はUnsupported Media Typeであり、RFC 7231で定義されているHTTPプロトコルの標準仕様に含まれます。このエラーが発生すると、サーバーはリクエストボディの処理を拒否し、クライアント側でメディアタイプの修正が必要となることを示します。
415エラーが発生する主な原因
Content-Typeヘッダーの指定ミスが、415エラーの最も一般的な原因となります。例えば、JSONデータを送信する際にContent-Type: application/jsonを指定すべきところを、text/plainやapplication/x-www-form-urlencodedと誤って指定してしまうケースがあります。
| 原因 | 具体例 |
|---|---|
| Content-Type未指定 | ヘッダーに何も設定していない |
| 誤った形式指定 | JSON送信時にtext/plain指定 |
| サーバー非対応形式 | XMLのみ対応のAPIにJSON送信 |
| 文字エンコード不一致 | UTF-8以外で送信 |
また、マルチパートフォームデータでのファイルアップロード時に、boundaryパラメータが欠落している場合も415エラーが発生します。サーバー側が特定のメディアタイプのみを受け付ける設定になっている場合、それ以外の形式でデータを送信すると必ずこのエラーが返されます。
JavaScriptでの415エラー対処方法
fetchAPIやAxiosを使用したHTTPリクエストでは、headersオブジェクトに正しいContent-Typeを明示的に設定することが重要です。以下のコード例では、JSON形式のデータをPOSTリクエストで送信する際の正しい実装方法を示しています。
fetch('https://api.example.com/data', {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({
name: '山田太郎',
age: 30
})
})
.then(response => {
if (response.status === 415) {
console.error('メディアタイプが対応していません');
}
return response.json();
})
.catch(error => console.error('エラー:', error));
Axiosライブラリを使用する場合は、デフォルトでJSON形式のデータ送信時、自動的にContent-Type: application/jsonが設定されます。しかし、FormDataオブジェクトを使用したファイルアップロードの際は、Content-Typeを手動でmultipart/form-dataに設定する必要があり、boundary値もブラウザが自動生成するため明示的な指定は不要です。
※上記コンテンツの内容やソースコードはAIで確認・デバッグしておりますが、間違いやエラー、脆弱性などがある場合は、コメントよりご報告いただけますと幸いです。
ITやプログラミングに関するコラム
PythonをWebで実行する方法
共通テスト「情報Ⅰ」2年目で変わる、日本の教育と学び方
gitでブランチ(branch)を切り替える方法
git cloneでブランチを指定する方法
64GBのメモリが必要な人・不要な人の特徴
PCを再起動するコマンド一覧
CapsLock以外で大文字になる原因【Windows編】
パソコンで大文字になるのを解除する方法
面白いAIの活用事例を業界別に紹介
Gitでcommit(コミット)を取り消す方法
ITやプログラミングに関するニュース
サイボウズがkintone AIを正式提供、β版から約1年を経てクレジット制を導入
ロゼッタのラクヤクAIがCSRドラフト作成期間を90%以上短縮、従来4週間を約2日に
AI CROSSが不動産業界向け生成AI伴走支援を開始、アスコットの業務AI実装を実践サポート
日本情報クリエイトが「オーナー提案AIロボⅡ」売買査定を刷新、月1万円からW査定が回数無制限に
Wur株式会社がAI新規事業診断サービス「MVP事業診断レポート」をリリース、12の質問で事業構想を約10分で分析
バトンズがM&A専門家向け「AI概要書」β版を提供開始、企業概要書のドラフトを最速3分で自動生成
SCSKが観光DXサービス「Connexia」を開発、首里城公園でNFT活用の周遊促進が始動
Verdent AI発表、エンジニア不要でソフトウェアを構築する「AIエンジニアリングチーム」が登場
ゼネラルBREXAテクノロジーが外食・小売向けAIサービス「aimana」を開発、店長の意思決定をデータで支援
田中組がKencopa工程AIエージェント製品版を先行利用開始、建設現場の工程管理属人化を解消へ
