Ich beziehe mich auf https://firebase.google.com/docs/database/admin/startFirebase 3.6.9 Fehler: PERMISSION_DENIED Zugriff auf Datenbank auf Knoten SDK
I node.js Code haben, wie unten erwähnt:
var admin = require("firebase-admin");
var serviceAccount = require('mySdkJSONFile');
admin.initializeApp({
credential: admin.credential.cert({
projectId: "myProjectId",
clientEmail: "myClientEmail",
apiKey: "myApiKey",
privateKey: "myPrivateKey"
}),
databaseURL: "....",
databaseAuthVariableOverride: {
uid: "my-service-worker"
}
});
var db = admin.database();
var usersDB = db.ref("/users");
usersDB.set({
name: "myName",
date: "yesterday"
});
Und in der Datenbank werden die Regeln festgelegt, wie
{
"rules": {
"public": {
".read": false,
".write": false
},
"users": {
"$uid": {
".read": "auth.uid == 'my-service-worker'",
".write": "auth.uid == 'my-service-worker'"
}
}
}
}
Wenn für "/ user" ich Lese- und Schreibrechte auf True setzen, funktioniert alles gut, keine Config-Probleme.
Beachten Sie, dass [Regeln sind nicht Filter] (https://firebase.google.com/docs/database/security/ Sicherungsdaten # rules_are_not_filters). Wenn Sie "/ users" abfragen, benötigen Sie eine Regel, die Lesezugriff ** auf dieser Ebene ** erlaubt, nicht auf der Ebene darunter. – Kato
Danke @Kato ... – manntsheth