我似乎无法让我的脚本接受我的不记名 token 。这是我的脚本:
func main(){
url := "https://www.mywebsite.com"
response, err := http.Get(url)
if err != nil {
log.Fatalln(err)
fmt.Print(err.Error())
os.Exit(1)
}
response.Header.Add("Authorization", os.ExpandEnv("$BEARER_TOKEN"))
fmt.Println(response.Header.Get("authorization"))
responseData, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatalln(err)
}
fmt.Println(string(responseData))
}
我做了fmt.Println(response.Header.Get("authorization"))
来查看它是否接受 token 并且正确打印了 token ,所以我不确定为什么它不接受它用于 GET 请求。
我也尝试过 response.Header.Set
而不是 response.Header.Add
,并且得到了相同的结果。
运行该脚本时得到的响应是:
{"code":16,"message":"token not valid for running mode"}
但我知道 token 是正确的,因为我在curl命令中尝试了它并且得到了我想要的输出
最佳答案
尝试使用http.NewRequest()并设置请求
header 授权
package main
import (
"fmt"
"io/ioutil"
"log"
"net/http"
"os"
"time"
)
func main() {
url := "https://www.mywebsite.com"
client := http.Client{Timeout: 5 * time.Second}
request, err := http.NewRequest(http.MethodGet, url, nil)
request.Header.Set("Authorization", os.ExpandEnv("$BEARER_TOKEN"))
request.Header.Set("Content-Type", "application/json") // => your content-type
response, err := client.Do(request)
if err != nil {
panic(err)
}
responseData, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatalln(err)
}
fmt.Println(string(responseData))
}
关于go - 让 Golang 接受 GET 授权的 token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70696189/