【发布时间】:2019-02-14 05:52:57
【问题描述】:
我正在开发一个使用 Firebase Auth 和数据库的小型演示项目。 我为我的 firebase 数据库配置了以下规则
{
"rules": {
"users": {
"$uid": {
".read": "$uid === auth.uid",
".write": "$uid === auth.uid"
}
}
通过此规则,我希望经过身份验证的用户仅对其数据具有读写权限。
下面是试图保存数据的java代码。
DatabaseReference databaseReference= FirebaseDatabase.getInstance().getReference().child(FirebaseAuth.getInstance().getCurrentUser().getUid()).child("basic");
{
DemoModel demoModel=new DemoModel();
demoModel.setId(databaseReference.push().getKey());
demoModel.setUser("demoUser"); databaseReference.child(demoModel.getId()).setValue(demoModel).addOnCompleteListener(new OnCompleteListener<Void>() {
@Override
public void onComplete(@NonNull Task<Void> task) {
if(task.isSuccessful()){
Toast.makeText(DemoActivity.this, Constants.SUCCESSFUL, Toast.LENGTH_SHORT).show();
}else {
Toast.makeText(DemoActivity.this, Constants.FAILED, Toast.LENGTH_SHORT).show();
}
}
});
}
我得到的错误:W/RepoOperation: setValue at /xgjCUqcasda444WkgZFHTNRUB3/basic/-Lywe44rft566hhyYYfDS failed: DatabaseError: Permission denied W/DynamiteModule:未找到 com.google.firebase.auth 的本地模块描述符类。
我的数据库看起来像:
demoProject-dd4568
xgjCUqcasda444WkgZFHTNRUB3
-basic
-LE3gdfdffdfaza
id:"-LE3gdfdffdfaza"
user: "asdasd"
我哪里出错了。我没有太多线索。当我将规则更改为
{
"rules": {
".read":"auth != null",
".write":"auth != null"
}
}
它工作正常。但这并不安全。
【问题讨论】:
标签: android firebase firebase-realtime-database firebase-authentication