Maison > Article > développement back-end > Comment résoudre l'erreur « schéma de protocole non pris en charge » lors de l'authentification HTTP de base dans Go ?
Authentification HTTP de base dans Go : résolution des problèmes de redirection
Lors de la tentative d'authentification HTTP de base dans Go à l'aide du code fourni, les développeurs peuvent rencontrer l'erreur : "schéma de protocole non pris en charge ""." Cette erreur est probablement due à la gestion des redirections.
Gotcha et résolution
La subtilité surgit lorsque le site Web effectue une redirection. Dans Go, lors des redirections, les en-têtes personnalisés spécifiés dans la requête d'origine sont perdus. Pour résoudre ce problème, une fonction de redirection personnalisée doit être définie pour rétablir les en-têtes.
Code mis à jour avec fonction de redirection personnalisée
L'extrait de code suivant illustre le script mis à jour qui inclut la fonction de redirection :
func basicAuth(username, password string) string { auth := username + ":" + password return base64.StdEncoding.EncodeToString([]byte(auth)) } func redirectPolicyFunc(req *http.Request, via []*http.Request) error{ req.Header.Add("Authorization","Basic " + basicAuth("username1","password123")) return nil } func main() { client := &http.Client{ Jar: cookieJar, CheckRedirect: redirectPolicyFunc, } req, err := http.NewRequest("GET", "http://localhost/", nil) req.Header.Add("Authorization","Basic " + basicAuth("username1","password123")) resp, err := client.Do(req) }
Avec cette modification, la fonction de redirection personnalisée garantit que l'en-tête d'authentification est ajouté aux demandes de redirection ultérieures, résolvant l'erreur et l'activation de l'authentification HTTP.
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!