Effectuer une requête POST codée en URL à l'aide de http.NewRequest(...)
En s'appuyant sur les principes fondamentaux des requêtes HTTP, les développeurs nécessitent souvent la possibilité de construire des requêtes avec des caractéristiques spécifiques, telles que celles avec une charge utile POST codée en URL. Cet article approfondira les spécificités de la création de telles requêtes à l'aide de la méthode polyvalente http.NewRequest(...).
Traditionnellement, les données codées en URL sont incluses dans la chaîne de requête URL. Cependant, l'utilisation de la méthode http.NewRequest(...) permet un meilleur contrôle sur la gestion des en-têtes. Dans ce scénario, laisser le corps de la requête vide tout en ajoutant la requête à l'URL n'est pas une approche appropriée.
La solution réside dans la fourniture de la charge utile codée en URL sous forme de chaîne via l'interface io.Reader, qui est élégamment démontré dans le code suivant :
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 }
En incorporant la chaîne codée en URL dans le corps de la requête via strings.NewReader(), la requête HTTP est correctement configurée pour fournir le charge utile prévue. Cette approche révisée élimine l'erreur 400 BAD REQUEST et garantit que l'API interprète correctement les données transmises.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!