Go で HTTP リクエストの認証 Cookie を処理するにはどうすればよいですか?
Nov 08, 2024 pm 10:56 PMGo での HTTP クエリの認証処理の改善
問題:
次のコードを考えてみましょう。 HTTPリクエストを実行するための認証:
client := &http.Client{} // Authenticate req, err := http.NewRequest("GET", "http://164.99.113.32/Authenticate", nil) req.SetBasicAuth("<username>", "<password>") resp, err := client.Do(req) if err != nil { fmt.Printf("Error : %s", err) } // Get Details req.URL, _ = url.Parse("http://164.99.113.32/Details") resp, err = client.Do(req) if err != nil { fmt.Printf("Error : %s", err) }
認証に成功すると、サーバー側に問題がないにもかかわらず、「/Details」への後続のリクエストが 401 アクセス拒否エラーで失敗します。
解決策:
これを解決するには、Cookie jar を利用してセッション情報を管理する必要があります。 Go の HTTP クライアントはデフォルトではこれを処理しないため、カスタム Cookie jar 実装を定義する必要があります:
type myjar struct { jar map[string] []*http.Cookie } func (p* myjar) SetCookies(u *url.URL, cookies []*http.Cookie) { fmt.Printf("The URL is : %s\n", u.String()) fmt.Printf("The cookie being set is : %s\n", cookies) p.jar [u.Host] = cookies } func (p *myjar) Cookies(u *url.URL) []*http.Cookie { fmt.Printf("The URL is : %s\n", u.String()) fmt.Printf("Cookie being returned is : %s\n", p.jar[u.Host]) return p.jar[u.Host] }
メイン関数で、カスタム Cookie jar を初期化し、HTTP クライアントに割り当てます:
jar := &myjar{} jar.jar = make(map[string] []*http.Cookie) client.Jar = jar
この実装により、後続のリクエストは「/Details」エンドポイントに正常にアクセスできます。
以上がGo で HTTP リクエストの認証 Cookie を処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?
