ホームページ >バックエンド開発 >Golang >golang で net/http/httptest.NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法

golang で net/http/httptest.NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法

王林
王林オリジナル
2023-11-18 14:48:36735ブラウズ

golang で net/http/httptest.NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法

毎日の Go 言語開発プロセスでは、特に Web アプリケーションを開発する場合、セキュリティ関連の機能をテストするために HTTPS サーバーを起動する必要がよくあります。現時点では、Go 言語の組み込み net/http/httptest.NewTLSServer 関数を使用して、テスト用の一時的な HTTPS サーバーを作成できます。

そこで、この記事では、NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法を紹介し、具体的なコード例も示します。

1. 使用方法

NewTLSServer 関数は net/http/httptest パッケージ内の関数であり、HTTP テスト サーバーを作成するために使用できます。その関数のプロトタイプは次のとおりです。

func NewTLSServer(handler http.Handler) *httptest.Server

このうち、ハンドラー パラメーターは HTTP リクエスト プロセッサであり、HTTP リクエストを処理して HTTP レスポンスを返すために使用されます。

戻り値は、作成された HTTP テスト サーバーを表す *httptest.Server 型のポインターです。

NewTLSServer 関数を使用すると、次のように呼び出すだけで一時的な HTTPS サーバーを起動できます:

server := httptest.NewTLSServer(handler)

このうち、ハンドラーは HTTP リクエスト プロセッサであり、独自に定義できます。または別のライブラリによって提供されるプロセッサ。

ここで作成した HTTPS サーバーは一時的なサーバーであり、その証明書は一時的に生成されるため、実際の運用環境では使用せず、テストおよび開発環境での使用にのみ適していることに注意してください。 。

2. 具体的な例

次に、具体的な例を使用して、NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法を示します。

サンプル コードでは、HTTP リクエストを処理し、HTTP レスポンスを返す HTTP リクエスト プロセッサを定義します。テスト関数では、一時的な HTTPS サーバーを作成し、それに HTTP リクエストを送信して、HTTP レスポンスの内容を出力します。

具体的なコードは次のとおりです:

package main

import (
    "fmt"
    "net/http"
    "net/http/httptest"
)

func handler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprint(w, "Hello World!")
}

func test() {
    server := httptest.NewTLSServer(http.HandlerFunc(handler))
    defer server.Close()

    resp, err := server.Client().Get(server.URL)
    if err != nil {
        panic(err)
    }
    defer resp.Body.Close()

    fmt.Println(resp.Status)
    fmt.Println(resp.Header)
    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        panic(err)
    }
    fmt.Println(string(body))
}

func main() {
    test()
}

上記のコードでは、まず HTTP リクエストを処理し、HTTP レスポンスを返す HTTP リクエスト プロセッサ ハンドラを定義します。これは 2 つのパラメータを受け取ります: HTTP 応答データの書き込みに使用される http.ResponseWriter タイプのパラメータ w と、HTTP 要求データの保存に使用される *http.Request タイプのパラメータ r です。

ハンドラー関数では、HTTP 応答に「Hello World!」というテキスト文字列を 1 行書き込むだけです。

次に、テスト関数を定義します。テスト関数では、NewTLSServer 関数を使用して一時的な HTTPS サーバーを作成し、定義したハンドラー関数をパラメーターとしてそれに渡します。次に、server.Client().Get(server.URL) を呼び出して、HTTP GET リクエストをこの HTTPS サーバーに送信し、HTTP 応答データを保存します。最後に、HTTP 応答のステータス コード、応答ヘッダー、応答内容を出力します。

このプログラムを実行すると、出力は次のようになります:

200 OK
map[Content-Length:[12] Content-Type:[text/plain; charset=utf-8]]
Hello World!

これは、一時的な HTTPS サーバーが正常に起動し、それに HTTP リクエストを正常に送信して HTTP レスポンスを取得できることを示しています。

3. 結論

この記事では、Go 言語の net/http/httptest.NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法を学びました。また、NewTLSServer 関数を使用して HTTP 要求ハンドラーを構築し、それに HTTP 要求を送信する方法を示す具体的なコード例も提供します。この記事で提供されているサンプル コードは参照のみを目的としており、必要に応じて変更して使用できます。

以上がgolang で net/http/httptest.NewTLSServer 関数を使用して一時的な HTTPS サーバーを起動する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。