Maison >développement back-end >Golang >Pourquoi est-ce que je reçois une erreur « Schéma de protocole non pris en charge » lors de la mise en œuvre de l'authentification HTTP de base dans Go ?

Pourquoi est-ce que je reçois une erreur « Schéma de protocole non pris en charge » lors de la mise en œuvre de l'authentification HTTP de base dans Go ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-21 07:24:10562parcourir

Why Am I Getting an

Dépannage de l'authentification HTTP de base dans Go

En tentant d'implémenter l'authentification HTTP de base, un développeur rencontre une erreur de schéma de protocole non pris en charge. En examinant l'extrait de code fourni, l'erreur réside dans l'initialisation de la requête.

req, err := http.NewRequest("GET", "mydomain.example", nil)

Le problème provient de l'utilisation d'un schéma de protocole vide. Pour rectifier cette erreur, la demande doit spécifier explicitement le schéma de protocole. Dans le cas d'une authentification HTTP de base, le schéma de protocole doit être "http" ou "https".

En spécifiant correctement le schéma de protocole, la demande sera envoyée en utilisant le protocole approprié et contournera l'erreur de schéma de protocole non pris en charge. :

req, err := http.NewRequest("GET", "http://mydomain.example", nil)

Avec cette correction, l'authentification HTTP de base devrait fonctionner comme prévu. Cependant, il convient de noter que si le site Web consulté effectue des redirections, Go peut supprimer les en-têtes spécifiés. Pour résoudre ce problème, une fonction de redirection personnalisée peut être implémentée pour rajouter l'en-tête d'autorisation après les redirections.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn