gpt4 book ai didi

google-app-engine - 在 App Engine 中创建签名 URL 时遇到问题

转载 作者:IT王子 更新时间:2023-10-29 02:13:45 25 4
gpt4 key购买 nike

我正在尝试创建一个签名 URL,以从一个用 Go 编写的 App Engine 应用程序下载 Google Cloud Storage 中的文件。我正在使用的 App Engine 中有一种巧妙的签名方法,[理论上] 允许我避免在我的应用程序中放置私钥。但是,这些 URL 似乎不起作用:我总是收到 403“SignatureDoesNotMatch”错误。有什么想法吗?

代码如下:

func createDownloadURL(c context.Context, resource string, validUntil time.Time, bucket string) (string, error) {
serviceAccount, err := appengine.ServiceAccount(c)
if err != nil {
return "", err
}

// Build up the string to sign.
validUntilString := strconv.FormatInt(validUntil.Unix(), 10)
toSign := []string{
"GET", // http verb (required)
"", // content MD5 hash (optional)
"", // content type (optional)
validUntilString, // expiration (required)
resource, // resource (required)
}

// Sign it.
_, signedBytes, err := appengine.SignBytes(c, []byte(strings.Join(toSign, "\n")))
if err != nil {
return "", err
}
signedString := base64.StdEncoding.EncodeToString(signedBytes)

// Build and return the URL.
arguments := url.Values{
"GoogleAccessId": {serviceAccount},
"Expires": {validUntilString},
"Signature": {signedString},
}
return fmt.Sprintf("https://storage.googleapis.com/%s/%s?%s", bucket, resource, arguments.Encode()), nil
}

最佳答案

已解决。我的代码有 2 个问题。

我在构建 toSign 时忘记包含存储桶名称。修复:

fmt.Sprintf("/%s/%s", bucket, resource),         // resource (required)

这返回了一个 AccessDenied 错误——进展!

第二个错误是使用 XML API storage.googleapis.com 而不是经过身份验证的浏览器端点 storage.cloud.google.com。修复:

return fmt.Sprintf("https://storage.cloud.google.com/%s/%s?%s", bucket, resource, arguments.Encode()), nil

这有效。

关于google-app-engine - 在 App Engine 中创建签名 URL 时遇到问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38237088/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com