首页 > 解决方案 > 错误 403 - 没有 storage.objects.create 访问权限

问题描述

我正在尝试使用 Laravel (PHP) 将图像上传到我的 Firebase 存储。

public function uploadObject($bucketName, $objectName, $source) {
    $projectId = 'cloudestate-d10da';
    $storage = new StorageClient([
        'projectId' => $projectId,
        'keyFilePath' => __DIR__.'/StorageAcc.json'
    ]);
    $file = fopen($source, 'r');
    $bucket = $storage->bucket("images");
    $object = $bucket->upload($file, [
        'name' => $objectName
    ]);
    printf('Uploaded %s to gs://%s/%s' . PHP_EOL, basename($source), $bucketName, $objectName);
}

但是当我尝试运行它时,我收到以下错误:

{
"error": {
"errors": [
    {
        "domain": "global",
        "reason": "forbidden",
        "message": "storageacc@cloudestate-d10da.iam.gserviceaccount.com does not have storage.objects.create access to images/testezc.png."
    }
],
"code": 403,
"message": "storageacc@cloudestate-d10da.iam.gserviceaccount.com does not have storage.objects.create access to images/testezc.png."
}

}

我还给了我的服务帐户“所有者”角色,但似乎没有修复错误。

我的谷歌云控制台

标签: phpfirebasegoogle-cloud-storagefirebase-storage

解决方案


首先,您必须验证使用的配置变量是否与您尝试运行的项目相同。尝试打印环境变量。

console.log(process.env.FIREBASE_CONFIG)

Firebase 默认建立此配置。如果你想改变这个变量,你可以使用。

curl -sL https://firebase.tools | bash

然后继续验证自己:

firebase login

然后列出可用的项目:

firebase projects:list

查看所有项目别名:

firebase use

然后为了匹配项目配置变量,将您正在使用的别名设置为当前本地环境。

firebase use <alias>

最后,验证配置变量是否是您需要的。


推荐阅读