이 문서에서는 컨텍스트의 컨텍스트 값 전송(코드 예제)에 대해 소개합니다. 특정 참조 값이 있으므로 도움이 될 수 있습니다.
이 기사는 컨텍스트 사용에 대한 체계적인 논의로 시작됩니다. 여기서는 직장에서 어려운 문제를 해결하기 위해 컨텍스트를 합리적으로 사용할 수 있습니다.
컨텍스트는 시간 초과 처리 외에도 데이터를 저장하는 데 사용될 수도 있습니다. 여러 컨텍스트에서 데이터를 전달해야 하는 경우 이 문서에서 언급된 지식이 유용할 수 있습니다.
샘플 코드
샘플 코드는 간단한 http 서비스입니다. 로그인 후 홈페이지로 이동하는 과정은 가드 미들웨어를 통해 이루어집니다. 물론, 샘플 코드는 이 글의 초점이 아닌 데이터베이스 연결과 같은 다른 처리를 수행하지 않습니다.
guard 함수는 쿠키를 읽은 후 쿠키 값을 컨텍스트에 쓰고 전체 요청에서 "투명"하다고 말할 수 있습니다. 보호해야 하는 인터페이스에 접근 시 쿠키가 제공되지 않는 것으로 감지하고, 단말에서 직접 요청을 하는 경우 r.WithContext를 통해 사용자 이름 값을 쿠키에 저장하여 비즈니스 인터페이스의 단점을 직접적으로 방지합니다. 쿠키를 읽고 있어요. 나중에 인증 알고리즘이 변경되면 비즈니스 코드를 변경할 필요가 없고 미들웨어만 직접 변경하면 되기 때문이다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!