在 Go 应用程序中使用服务帐户 json 密钥文件时获取'请求具有无效的身份验证凭据”
php小编香蕉在Go应用程序中使用服务帐户JSON密钥文件时,可能会遇到"请求具有无效的身份验证凭据"的问题。这个问题通常是由于密钥文件的格式或内容有误导致的。要解决这个问题,可以检查密钥文件的格式是否正确,并确保密钥文件中包含了正确的认证信息。另外,还可以尝试重新生成密钥文件,并确保将其正确配置到应用程序中。通过这些方法,就能够解决"请求具有无效的身份验证凭据"的问题,正常使用服务帐户JSON密钥文件。
问题内容
我正在 gcp 项目上开发 go 应用程序,并且正在使用 google 云日志记录服务。我在运行应用程序时遇到问题,因为它说当我使用服务帐户 json 密钥时我的身份验证凭据无效。
这是有错误的代码片段:
c, cerr := load(".env") if cerr != nil { log.fatalf("could not load config: %s", cerr) return } // initializes logger which writes to stdout ctx := context.background() opt := option.withcredentialsfile(c.googleapplicationcredentials); loggerclient, clienterr := logging.newclient(ctx, "poc-projects-01", opt) if clienterr != nil { log.fatal(clienterr) }
这是 load()
函数的定义:
func Load(file string) (*Config, error) { viper.SetConfigFile(file) viper.AddConfigPath(".") viper.AutomaticEnv() if err := viper.ReadInConfig(); err != nil { return nil, err } c := &Config{ GoogleApplicationCredentials: viper.GetString("GOOGLE_APPLICATION_CREDENTIALS"), } return c, nil }
我有一个 .env
文件,其中包含以下内容:
google_application_credentials=json/path-to-json.json
我不知道为什么它说令牌已过期,即使这是我在 gcp 和本地计算机上拥有的唯一服务帐户 json 密钥。
解决方法
您可以运行gcloud auth application-default login
a> 并确保您已将其设置为正确的项目。
检查 googleapplicationscredentals
是否设置了有效的 json 密钥,并且环境变量设置是否正确,请运行以下命令来检查
echo $google_application_credentials
如果该命令未返回 json 密钥的正确路径,您可以使用以下命令设置环境变量:
export GOOGLE_APPLICATION_CREDENTIALS=/path/to/json/key.json
验证 json 密钥有效并且环境变量设置正确后,您应该能够运行您的应用程序。或者,您可以尝试删除 .env 文件,然后使用 服务帐户 json 密钥,它应该重新生成令牌并使其有效。
附加问题排查文档 a>供参考。
以上是在 Go 应用程序中使用服务帐户 json 密钥文件时获取'请求具有无效的身份验证凭据”的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

OpenSSL,作为广泛应用于安全通信的开源库,提供了加密算法、密钥和证书管理等功能。然而,其历史版本中存在一些已知安全漏洞,其中一些危害极大。本文将重点介绍Debian系统中OpenSSL的常见漏洞及应对措施。DebianOpenSSL已知漏洞:OpenSSL曾出现过多个严重漏洞,例如:心脏出血漏洞(CVE-2014-0160):该漏洞影响OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻击者可利用此漏洞未经授权读取服务器上的敏感信息,包括加密密钥等。

本文演示了创建模拟和存根进行单元测试。 它强调使用接口,提供模拟实现的示例,并讨论最佳实践,例如保持模拟集中并使用断言库。 文章

本文探讨了GO的仿制药自定义类型约束。 它详细介绍了界面如何定义通用功能的最低类型要求,从而改善了类型的安全性和代码可重复使用性。 本文还讨论了局限性和最佳实践

本文讨论了GO的反思软件包,用于运行时操作代码,对序列化,通用编程等有益。它警告性能成本,例如较慢的执行和更高的内存使用,建议明智的使用和最佳

本文讨论了GO中使用表驱动的测试,该方法使用测试用例表来测试具有多个输入和结果的功能。它突出了诸如提高的可读性,降低重复,可伸缩性,一致性和A

本文使用跟踪工具探讨了GO应用程序执行流。 它讨论了手册和自动仪器技术,比较诸如Jaeger,Zipkin和Opentelemetry之类的工具,并突出显示有效的数据可视化
