カテゴリ: Go言語 更新日: 2025/12/25

Go言語でHTTPステータスコードを正しく設定する基本!初心者でもわかるWeb開発

Go言語のHTTPステータスコードを正しく設定する基本
Go言語のHTTPステータスコードを正しく設定する基本

先生と生徒の会話形式で理解しよう

生徒

「先生、Go言語でWebアプリを作っているんですが、HTTPステータスコードって何ですか?」

先生

「HTTPステータスコードは、Webサーバーからブラウザやクライアントに返す数字で、リクエストが成功したか、エラーが発生したかを示します。」

生徒

「例えばどんなコードがありますか?」

先生

「例えば、成功した場合は200、ページが見つからない場合は404、サーバーエラーの場合は500などがあります。」

生徒

「なるほど。Go言語ではどうやって設定するんですか?」

先生

「それでは、基本的な使い方を順番に見ていきましょう。」

1. Go言語でHTTPステータスコードを返す方法

1. Go言語でHTTPステータスコードを返す方法
1. Go言語でHTTPステータスコードを返す方法

Go言語の標準ライブラリにはnet/httpパッケージがあり、http.ResponseWriterを使ってHTTPステータスコードを設定できます。WriteHeaderメソッドでコードを指定し、その後にレスポンス本文を書きます。


package main

import (
    "fmt"
    "net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
    w.WriteHeader(http.StatusOK) // 200 OK
    fmt.Fprintln(w, "リクエストは成功しました!")
}

func main() {
    http.HandleFunc("/", handler)
    http.ListenAndServe(":8080", nil)
}

この例では、http.StatusOKを使って200ステータスを返しています。WriteHeaderはレスポンス本文より前に呼ぶ必要があります。

2. よく使うHTTPステータスコード一覧

2. よく使うHTTPステータスコード一覧
2. よく使うHTTPステータスコード一覧

HTTPステータスコードは大きく5つのカテゴリに分かれます。1xxは情報、2xxは成功、3xxはリダイレクト、4xxはクライアントエラー、5xxはサーバーエラーです。代表的なコードをいくつか紹介します。

  • 200 OK:リクエスト成功
  • 201 Created:新しいリソースが作成された
  • 400 Bad Request:リクエストが不正
  • 401 Unauthorized:認証が必要
  • 403 Forbidden:アクセス禁止
  • 404 Not Found:ページが見つからない
  • 500 Internal Server Error:サーバー内部エラー

Go言語では、これらのコードに対応する定数がhttp.StatusOKhttp.StatusNotFoundなどとして用意されており、数字を直接書くより可読性が高くなります。

3. ステータスコードによるエラーハンドリング

3. ステータスコードによるエラーハンドリング
3. ステータスコードによるエラーハンドリング

クライアントからのリクエストに問題がある場合は、適切なステータスコードを返してエラーを伝えることが重要です。


func errorHandler(w http.ResponseWriter, r *http.Request) {
    path := r.URL.Path
    if path != "/ok" {
        w.WriteHeader(http.StatusNotFound) // 404 Not Found
        fmt.Fprintln(w, "ページが見つかりません")
        return
    }
    w.WriteHeader(http.StatusOK)
    fmt.Fprintln(w, "正常にアクセスできました")
}

この例では、リクエストURLが"/ok"でなければ404を返し、正常なら200を返します。これにより、ブラウザやAPIクライアントに正しい情報を伝えられます。

4. JSONレスポンスとステータスコードの組み合わせ

4. JSONレスポンスとステータスコードの組み合わせ
4. JSONレスポンスとステータスコードの組み合わせ

APIを作る場合、JSONレスポンスとステータスコードを組み合わせることがよくあります。Goではencoding/jsonパッケージを使ってJSONを返すことができます。


import (
    "encoding/json"
)

type Response struct {
    Message string `json:"message"`
}

func jsonHandler(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "application/json")
    w.WriteHeader(http.StatusOK)
    json.NewEncoder(w).Encode(Response{Message: "JSONレスポンス成功"})
}

このようにWriteHeaderでステータスコードを設定し、JSON形式でレスポンスを返すことで、クライアントに正しい情報と状態を伝えられます。

5. 注意点とベストプラクティス

5. 注意点とベストプラクティス
5. 注意点とベストプラクティス
  • WriteHeaderはレスポンス本文を書く前に必ず呼ぶ
  • HTTPステータスコードは意味に沿って正しく設定する(成功は2xx、エラーは4xx/5xxなど)
  • API開発では、ステータスコードとレスポンス内容を一貫させる
  • 数字より定数(http.StatusOKなど)を使うと可読性が向上

正しいステータスコードの設定は、WebアプリやAPIの信頼性を高め、開発や運用の効率化にも繋がります。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

まとめ

まとめ
まとめ

HTTPステータスコードを理解することの重要性

本記事では、Go言語を使ったWeb開発において欠かせないHTTPステータスコードの基本から、具体的な使い方、実践的な注意点までを段階的に解説してきました。HTTPステータスコードは、単なる数字ではなく、サーバーとクライアントの間で「処理結果を正確に伝えるための共通言語」です。ブラウザやAPIクライアントは、この数値をもとに次の動作を判断するため、正しく設定されていないと、動作不良や誤解を招く原因になります。

Go言語では net/http パッケージが非常に充実しており、http.ResponseWriterWriteHeader を使うだけで、HTTPステータスコードを明示的に制御できます。特に初心者の方は「レスポンスが表示されているから大丈夫」と考えがちですが、裏側でどのステータスコードが返っているかを意識することで、より品質の高いWebアプリケーションを作れるようになります。

成功と失敗を正しく伝える設計の考え方

記事内で紹介したように、成功時には 200 OK201 Created、クライアント側の入力ミスには 400 Bad Request、存在しないページには 404 Not Found、サーバー内部の問題には 500 Internal Server Error を返すなど、用途に応じた使い分けが重要です。これにより、フロントエンド開発者やAPI利用者がレスポンスの意味を直感的に理解できるようになります。

特にJSON APIを開発する場合は、ステータスコードとレスポンスボディの内容をセットで考えることが大切です。ステータスコードで大まかな結果を伝え、JSONの中身で詳細なメッセージやデータを返すことで、実用性の高いAPI設計が可能になります。

ステータスコードとJSONを組み合わせた実践例


type ApiResponse struct {
    Status  string `json:"status"`
    Message string `json:"message"`
}

func sampleHandler(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "application/json")

    if r.Method != "GET" {
        w.WriteHeader(http.StatusMethodNotAllowed)
        json.NewEncoder(w).Encode(ApiResponse{
            Status:  "error",
            Message: "このメソッドは許可されていません",
        })
        return
    }

    w.WriteHeader(http.StatusOK)
    json.NewEncoder(w).Encode(ApiResponse{
        Status:  "success",
        Message: "正常に処理されました",
    })
}

このように、Go言語ではHTTPステータスコードとJSONレスポンスを自然に組み合わせることができます。ステータスコードだけ、あるいはJSONだけに頼るのではなく、両方を意識することで、クライアントにとって分かりやすく、拡張性の高いWeb APIを構築できます。

初心者が意識しておきたいポイント

初心者のうちは、まず「成功は200」「見つからないは404」「エラーは500」という基本的な使い分けを確実に身につけることが大切です。そのうえで、WriteHeader をレスポンス本文より前に呼ぶ必要がある点や、数値ではなく http.StatusOK のような定数を使う習慣を意識すると、コードの読みやすさと保守性が向上します。

HTTPステータスコードを正しく扱えるようになると、Webアプリケーションの挙動が明確になり、デバッグやトラブルシューティングも格段に楽になります。これは小規模な個人開発だけでなく、チーム開発や実務の現場でも大きな強みになります。

先生と生徒の振り返り会話

生徒:「HTTPステータスコードって、ただの数字だと思っていましたが、意味を考えて使うと大事なんですね。」

先生:「そうですね。ステータスコードは、サーバーからの気持ちを数字で伝えるようなものです。」

生徒:「Go言語だと定数が用意されているので、意味も分かりやすかったです。」

先生:「その通りです。数字を直接書かずに定数を使うことで、コードを見ただけで意図が伝わります。」

生徒:「JSON APIと組み合わせると、実際のWebサービスっぽくなりますね。」

先生:「はい。今回学んだ内容をベースにすれば、実践的なWebアプリやAPI開発に十分対応できますよ。」

関連セミナーのご案内

【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導

「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。

本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。

具体的な開発内容と環境

【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。

【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。

この60分で得られる3つの理解

1. 環境構築の完全な理解

「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。

2. Go言語の基本構造(変数・型)

データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。

3. 読みやすいコードの書き方

ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。

※本講座は、将来的にバックエンドエンジニアクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。

セミナー画像

初めてのGo言語を一緒に学びましょう!

カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のwhile的なforループの使い方!条件式ループの基本を解説
New2
Go言語
Go言語プログラムの実行方法まとめ!VSCode・ターミナルでの実行手順を解説
New3
Swift
Swift意味とは?プログラミング言語・金融・鳥の違いを徹底解説
New4
Swift
Swift 戻り値の扱い方と複数戻り値の返し方|初心者でも分かる関数の基本
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語でリダイレクト処理を行う方法(http.Redirect)を初心者向けに解説
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.4
Java&Spring記事人気No4
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.5
Java&Spring記事人気No5
Go言語
Go言語のgo.modファイル完全ガイド!初心者でもわかる仕組みと書き方
No.6
Java&Spring記事人気No6
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.7
Java&Spring記事人気No7
Kotlin
Kotlinの演算子一覧と使い方!算術・比較・論理演算子の基本を解説
No.8
Java&Spring記事人気No8
Go言語
Go言語で条件式を1行で書くコツ!三項演算子の代替と短縮記法