登录
首页 >  Golang >  Go问答

无法通过独立的 Go 应用程序访问 GCP 的秘密管理器

来源:stackoverflow

时间:2024-03-20 14:15:31 266浏览 收藏

在尝试从独立 Go 应用程序访问 Google Cloud Platform (GCP) 的秘密管理器时,可能会遇到一个常见问题:无法创建 `secretmanager` 客户端,导致代码因空指针取消引用而引发恐慌。为了解决这个问题,需要在代码中添加 `panic` 或 `return` 语句,以便在出现错误时停止程序执行。通过添加这些语句,可以避免出现空指针恐慌,并正确处理 `secretmanager.NewClient` 返回的错误。

问题内容

我正在尝试从谷歌云功能访问gcp秘密管理器。下面是代码片段

// Package p contains an HTTP Cloud Function.
 package p

 import (
    "context"
    "fmt"
    
    

    secretmanager "cloud.google.com/go/secretmanager/apiv1"
        secretmanagerpb "google.golang.org/genproto/googleapis/cloud/secretmanager/v1"
)
   
 func main() {
    
    ctx := context.Background()
        client, err := secretmanager.NewClient(ctx)
        if err != nil {
                fmt.Errorf("failed to create secretmanager client: %v", err)
        }
        defer client.Close()
        name := "projects/485126440943/secrets/APIAdminServiceAccountLookupKey"
        // Build the request.
        req := &secretmanagerpb.GetSecretRequest{
                Name: name,
        }

        // Call the API.
        result, err := client.GetSecret(ctx, req)
        if err != nil {
                fmt.Errorf("failed to get secret: %v", err)
        }

        replication := result.Replication.Replication
        fmt.Printf("Found secret %s with replication policy %s\n", result.Name, replication)
        //return nil

    }

但我得到的 secretmanagerclient 为 nil ]。这就是为什么在运行代码后我收到以下错误:

恐慌:运行时错误:无效的内存地址或零指针取消引用 恐慌:运行时错误:无效的内存地址或零指针取消引用

如何解决这个问题? 提前致谢!!


正确答案


从您的代码中,我们可以看到您在出现错误时忘记停止程序。它会导致你出现 nil 指针恐慌,因为你访问了 client.getsecret(ctx, req) 中的 nil *secretmanager.client 方法。要解决这个问题,只需添加 panicreturn 语句即可。实现后,您将不再遇到 nil 指针恐慌,并且您将面临来自 secretmanager.newclient(ctx) 的错误。

package main

import (
    "context"
    "fmt"

    secretmanager "cloud.google.com/go/secretmanager/apiv1"
    secretmanagerpb "google.golang.org/genproto/googleapis/cloud/secretmanager/v1"
)

func main() {
    ctx := context.Background()
    client, err := secretmanager.NewClient(ctx)
    if err != nil {
        // stop your program from executing the next lines
        panic(fmt.Errorf("failed to create secretmanager client: %v", err))

        // you can also use return statement
        //
        // log.Println(fmt.Errorf("failed to create secretmanager client: %v", err))
        // return
    }
    defer client.Close()

    name := "projects/485126440943/secrets/APIAdminServiceAccountLookupKey"
    // Build the request.
    req := &secretmanagerpb.GetSecretRequest{
        Name: name,
    }

    // Call the API.
    result, err := client.GetSecret(ctx, req)
    if err != nil {
        panic(fmt.Errorf("failed to get secret: %v", err))
    }

    replication := result.Replication.Replication
    fmt.Printf("Found secret %s with replication policy %s\n", result.Name, replication)
    //return nil
}

理论要掌握,实操不能落!以上关于《无法通过独立的 Go 应用程序访问 GCP 的秘密管理器》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>