我正在尝试使用下面的代码进行基本的HTTP身份验证,但它会抛出以下错误:
2013/05/21 10:22:58获取mydomain.com:不支持的协议方案“” 退出状态1
func basicAuth() string {
var username string = "foo"
var passwd string = "bar"
client := &http.Client{}
req, err := http.NewRequest("GET", "mydomain.com", nil)
req.SetBasicAuth(username, passwd)
resp, err := client.Do(req)
if err != nil{
log.Fatal(err)
}
bodyText, err := ioutil.ReadAll(resp.Body)
s := string(bodyText)
return s
}
知道我可能做错了吗?
答案 0 :(得分:44)
潜在的“陷阱”是指您的网站是否进行了重定向... Go-lang会在重定向上删除您指定的标题。 (我必须做wireshark才能看到这个!你可以通过右击然后“检查元素”然后点击网络标签快速找到chrome中的颜色)
您需要定义一个重定向函数,将函数添加回来。
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)
}
答案 1 :(得分:33)
您需要为NewRequest指定协议,例如“http://”,请参阅here。
req, err := http.NewRequest("GET", "http://mydomain.com", nil)