使用golangGoogle云端存储身份验证

时间:2015-10-17 17:28:09

标签: go google-cloud-storage

我在服务器上运行了一个go应​​用程序。该应用程序需要访问权限以将图像保存到Google云端存储。从Google Cloud Storage authentication文档中可以看到如何创建PKCS12密钥。

我正在使用

import(
storage "google.golang.org/api/storage/v1"
)

如何将此密钥用于golang"存储"客户在申请中?

此致

1 个答案:

答案 0 :(得分:1)

func ExampleJWTConfigFromJSON() {
    // Your credentials should be obtained from the Google
    // Developer Console (https://console.developers.google.com).
    // Navigate to your project, then see the "Credentials" page
    // under "APIs & Auth".
    // To create a service account client, click "Create new Client ID",
    // select "Service Account", and click "Create Client ID". A JSON
    // key file will then be downloaded to your computer.
    data, err := ioutil.ReadFile("/path/to/your-project-key.json")
    if err != nil {
        log.Fatal(err)
    }
    conf, err := google.JWTConfigFromJSON(data, "https://www.googleapis.com/auth/bigquery")
    if err != nil {
        log.Fatal(err)
    }
    // Initiate an http.Client. The following GET request will be
    // authorized and authenticated on the behalf of
    // your service account.
    client := conf.Client(oauth2.NoContext)
    client.Get("...")
}

-

func JWTConfigFromJSON(jsonKey []byte, scope ...string) (*jwt.Config, error)
{
    var key struct {
        Email      string `json:"client_email"`
        PrivateKey string `json:"private_key"`
    }
    if err := json.Unmarshal(jsonKey, &key); err != nil {
        return nil, err
    }
    return &jwt.Config{
        Email:      key.Email,
        PrivateKey: []byte(key.PrivateKey),
        Scopes:     scope,
        TokenURL:   JWTTokenURL,
    }, nil
}

详情:

https://github.com/golang/oauth2/blob/master/google/example_test.go https://github.com/golang/oauth2/blob/master/google/google.go

希望这会有所帮助。