JSON 요청 본문을 구문 분석하는 방법은 무엇입니까? 요청 본문을 읽으려면 ioutil.ReadAll()을 사용하십시오. json.Unmarshal()을 사용하여 JSON 본문을 구문 분석합니다. 미들웨어를 사용하여 HTTP 요청이 인증되었는지 어떻게 확인할 수 있나요? 토큰의 유효성을 검사하는 미들웨어 기능을 만듭니다. 라우터에 경로를 등록하고 미들웨어를 사용하여 요청을 처리합니다. HTTP 요청 컨텍스트를 통해 데이터베이스 연결을 얻는 방법은 무엇입니까? 데이터베이스 연결을 얻기 위한 미들웨어 기능을 만듭니다. 미들웨어 기능의 컨텍스트에 연결을 저장합니다. 라우터에 경로를 등록하고 미들웨어를 사용하여 요청을 처리합니다.
GoLang 프레임워크 개발 시 흔히 발생하는 문제에 대한 분석 및 답변
GoLang 프레임워크를 개발하는 과정에서 우리는 다양한 문제에 직면하게 됩니다. 이 기사에서는 가장 일반적인 몇 가지 질문을 수집하고 자세한 답변과 실제 사례를 제공합니다.
질문 1: JSON 요청 본문을 구문 분석하는 방법은 무엇입니까?
// 解析 JSON 请求正文 func parseJSON(w http.ResponseWriter, r *http.Request) (map[string]interface{}, error) { body, err := ioutil.ReadAll(r.Body) if err != nil { return nil, err } defer r.Body.Close() var bodyMap map[string]interface{} if err := json.Unmarshal(body, &bodyMap); err != nil { return nil, err } return bodyMap, nil } // 实战案例 func handleJSON(w http.ResponseWriter, r *http.Request) { bodyMap, err := parseJSON(w, r) if err != nil { http.Error(w, "Invalid JSON", http.StatusBadRequest) return } // 处理 JSON 请求正文 }
질문 2: 미들웨어를 사용하여 HTTP 요청이 인증되었는지 확인하는 방법은 무엇입니까?
// 验证 HTTP 请求是否经过身份验证的中间件 func AuthMiddleware(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { // 获取 Authorization 头 authToken := r.Header.Get("Authorization") // 验证令牌有效性 if !validateToken(authToken) { http.Error(w, "Unauthorized", http.StatusUnauthorized) return } // 继续执行请求处理程序 next.ServeHTTP(w, r) }) } // 实战案例 func main() { // 创建一个 HTTP 路由器 router := http.NewServeMux() // 注册路由,使用 AuthMiddleware 验证请求 router.HandleFunc("/protected", AuthMiddleware(http.HandlerFunc(handleProtected))) // 启动服务器 http.ListenAndServe(":8080", router) }
질문 3: HTTP 요청 컨텍스트를 통해 데이터베이스 연결을 얻는 방법은 무엇입니까?
// 获取数据库连接的中间件 func DBMiddleware(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { // 获取数据库连接 db, err := connectDB() if err != nil { http.Error(w, "Unable to connect to the database", http.StatusInternalServerError) return } // 将数据库连接存储在上下文中 ctx := context.WithValue(r.Context(), "db", db) // 继续执行请求处理程序 next.ServeHTTP(w, r.WithContext(ctx)) }) } // 实战案例 func main() { // 创建一个 HTTP 路由器 router := http.NewServeMux() // 注册路由,使用 DBMiddleware 获取数据库连接 router.HandleFunc("/protected", DBMiddleware(http.HandlerFunc(handleProtected))) // 启动服务器 http.ListenAndServe(":8080", router) }
위 내용은 Golang 프레임워크 개발의 일반적인 문제에 대한 분석 및 답변의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!