我想知道存储规则部署在Firebase中的工作原理。
在Firebase存储中,我有2个桶app.appspot.com
和app-mybucket
。在我的本地机器上,我有一个storage.rules
文件,看起来像这样:
service firebase.storage {
match /b/app.appspot.com/o {
match /{allPaths=**} {
allow read, write: if request.auth != null;
}
}
match /b/app-mybucket/o {
match /{userId}/{allPaths=**} {
allow read, write: if request.auth.uid == userId;
}
}
}
当我firebase deploy --only storage
这些规则被发送到默认的app.appshpot.com
桶,似乎没有任何东西被发送到app-mybucket
。我想知道一种可以将规则部署到所有存储桶的方法。
在firebase.json文件中,您可以指定以下内容:
"storage": [{
"rules": "my-appspot.rules",
"bucket": "app.appspot.com"
},
{
"rules": "my-bucket.rules",
"bucket": "app-mybucket"
}]
上面的示例使用每个存储桶的不同规则,如果您愿意,也可以为每个存储桶使用相同的规则。