http.NewRequest(...)를 사용하여 URL 인코딩된 POST 요청 만들기
HTTP 요청의 기본 원칙을 바탕으로 개발자는 URL로 인코딩된 POST 페이로드가 있는 요청과 같은 특정 특성을 가진 요청을 구성하는 기능이 필요한 경우가 많습니다. 이 기사에서는 다용도 http.NewRequest(...) 메소드를 사용하여 이러한 요청을 작성하는 세부 사항을 살펴보겠습니다.
전통적으로 URL 인코딩 데이터는 URL 쿼리 문자열에 포함됩니다. 그러나 http.NewRequest(...) 메서드를 활용하면 헤더 관리를 더 효과적으로 제어할 수 있습니다. 이 시나리오에서 URL에 쿼리를 추가하는 동안 요청 본문을 비워 두는 것은 적합한 접근 방식이 아닙니다.
해결책은 io.Reader 인터페이스를 통해 URL 인코딩 페이로드를 문자열로 제공하는 것입니다. 다음 코드에 우아하게 설명되어 있습니다.
package main import ( "fmt" "net/http" "net/url" "strconv" "strings" ) func main() { apiUrl := "https://api.com" resource := "/user/" data := url.Values{} data.Set("name", "foo") data.Set("surname", "bar") u, _ := url.ParseRequestURI(apiUrl) u.Path = resource urlStr := u.String() // "https://api.com/user/" client := &http.Client{} r, _ := http.NewRequest(http.MethodPost, urlStr, strings.NewReader(data.Encode())) // URL-encoded payload r.Header.Add("Authorization", "auth_token=\"XXXXXXX\"") r.Header.Add("Content-Type", "application/x-www-form-urlencoded") resp, _ := client.Do(r) fmt.Println(resp.Status) // Output: 200 OK }
strings.NewReader()를 통해 요청 본문 내에 URL 인코딩 문자열을 통합하면 HTTP 요청이 의도한 페이로드를 전달하도록 올바르게 구성되었습니다. 이 수정된 접근 방식은 400 BAD REQUEST 오류를 제거하고 API가 전송된 데이터를 올바르게 해석하도록 보장합니다.
위 내용은 Go의 `http.NewRequest(...)`를 사용하여 URL 인코딩된 POST 요청을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!