让 Golang 接受 GET 授权的令牌

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.Setresponse.Header.Add但结果相同。

当我运行该脚本时得到的响应是: {"code":16,"message":"token not valid for running mode"}但我知道令牌是正确的,因为我在curl命令中尝试了它并且得到了我想要的输出

Dav*_*ter 5

尝试使用 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)

  • 因为这是他的代码。我只更改了请求部分,其他部分保持不变。 (3认同)