use*_*554 2 authorization get go http-headers bearer-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))
}
Run Code Online (Sandbox Code Playgroud)
我确实fmt.Println(response.Header.Get("authorization"))
查看了它是否接受令牌并正确打印了令牌,所以我不确定为什么它不接受 GET 请求。
我也尝试过response.Header.Set
,response.Header.Add
但结果相同。
当我运行该脚本时得到的响应是:
{"code":16,"message":"token not valid for running mode"}
但我知道令牌是正确的,因为我在curl命令中尝试了它并且得到了我想要的输出
尝试使用 http.NewRequest() 并设置request
标头授权
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))
}
Run Code Online (Sandbox Code Playgroud)