この記事では、コンテキスト値の転送について説明します (コード例)。必要な方は参考にしていただければ幸いです。
この記事では、コンテキストの使用方法について体系的に説明します。ここでは、仕事上のいくつかの困難な問題を解決するためにコンテキストを合理的に使用できるようにします。
コンテキストは、タイムアウト処理に加えて、データを保存するためにも使用できます。複数のコンテキストを渡すときにデータを渡す必要がある場合、この記事で説明されている知識が役に立ちます。
サンプル コード
サンプル コードは、ログイン後にホームページがガードを通じて認証されるという単純な http サービスです。ミドルウェア。もちろん、サンプル コードではデータベースへの接続などの他の処理は実行しませんが、これはこの記事の焦点ではありません。
ガード関数は Cookie を読み取った後、Cookie の値をコンテキストに書き込み、リクエスト全体で「透過的」であると言えます。保護する必要があるインターフェイスにアクセスする場合、Cookie が提供されていないことが検出され、端末リクエストが直接行われます。それ以外の場合は、ビジネス インターフェイスの欠点を直接回避するために、ユーザー名の値が r.WithContext を通じて Cookie に保存されます。クッキーを読んでいます。後で認証アルゴリズムが変更された場合、ビジネス コードを変更する必要はなく、ミドルウェアを直接変更するだけで済むためです。
package main import ( "context" "fmt" "log" "net/http" "time" ) func main() { mux := http.NewServeMux() mux.HandleFunc("/", guard(home)) mux.HandleFunc("/login", login) log.Fatal(http.ListenAndServe(":8080", mux)) } // 登录 func login(w http.ResponseWriter, r *http.Request) { if r.URL.Query().Get("username") != "root" { http.Error(w, http.StatusText(401), 401) return } cookie := &http.Cookie{Name: "username", Value: "root", Expires: time.Now().Add(time.Hour)} http.SetCookie(w, cookie) http.Redirect(w, r, "/", 302) } func home(w http.ResponseWriter, r *http.Request) { username := r.Context().Value("username") fmt.Fprintf(w, "welcome login: %s", username.(string)) } // 守卫 func guard(handleFunc http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { // check username log.Printf("%s - %s\n", r.Method, r.RequestURI) cookie, err := r.Cookie("username") if err != nil || cookie == nil { // 如果username为空直接拦截 http.Error(w, http.StatusText(401), 401) return } handleFunc(w, r.WithContext(context.WithValue(r.Context(), "username", cookie.Value))) } }
この記事にはコードが非常に多く、内容はほとんどありません。皆さんがこのツールを有効に活用できることを願っています。
以上がコンテキストのコンテキスト値の受け渡しの概要 (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。