未处理的异常:PlatformException(执行get时出错,PERMISSION_DENIED:权限缺失或不足。,null)

时间:2020-09-24 03:15:23

标签: firebase flutter dart google-cloud-firestore firebase-authentication

每当应用启动时,都会出现此错误。我认为该错误主要是在saveUserInfoFirestore函数中。.我看到许多其他人也有同样的问题原因导致了他们的Firestore安全规则,但是我尝试了不同的规则,但它仍然显示相同的错误。

final GoogleSignIn gSignIn = GoogleSignIn();
final userReference = Firestore.instance.collection("Users");    
void initState(){
        super.initState();
        pageController=PageController();
        gSignIn.onCurrentUserChanged.listen((gSigninAccount) { ControlSingIn(gSigninAccount); },
            onError: (gError){
                print("Google signin error"+ gError);
            });
        gSignIn.signInSilently(suppressErrors: false).then((gSigninAccount) { ControlSingIn(gSigninAccount); }).
        catchError((onError){
          print("Signin silently error"+ onError);
        });
      }
    
      ControlSingIn(GoogleSignInAccount signInAccount) async{
    
        if(signInAccount != null){
          await saveUserInfotoFirestore();
          setState(() {
            isSignin = true;
          });
        }else{
          setState(() {
            isSignin = false;
          });
        }
    
      }
      saveUserInfotoFirestore() async{
          final GoogleSignInAccount gCurrentuser = gSignIn.currentUser;
          DocumentSnapshot documentSnapshot = await userReference.document(gCurrentuser.id).get();
    
          if(!documentSnapshot.exists){
            final username = await Navigator.push(context, MaterialPageRoute(builder: (context)=>CreateAccountPage()));
    
            userReference.document(gCurrentuser.id).setData({
              "id": gCurrentuser.id,
              "profileName": gCurrentuser.displayName,
              "username": username,
              "url": gCurrentuser.photoUrl,
              "email": gCurrentuser.email,
              "bio": "",
              "timestamp":timestamp
            });
            documentSnapshot = await userReference.document(gCurrentuser.id).get();
    
          }
          currentUser = User.fromDocument(documentSnapshot);
    
      }

这是我使用的Firestore安全规则:

rules_version = '2';
// Allow read/write access on all documents to any user signed in to the application
service cloud.firestore {
  match /databases/{database}/documents {
    match /messages/{document=**} {
      allow read, write: if true;
    }
  }
}

2 个答案:

答案 0 :(得分:1)

您的安全规则仅允许使用此匹配项访问名为“邮件”的单个集合:

    match /messages/{document=**} {
      allow read, write: if true;
    }

但是,您的代码正在尝试编写一个名为“ Users”的不同集合。您看到权限错误,因为您的规则完全不允许对该集合进行任何访问。您还必须编写另一条规则,以允许足够访问该集合。

我强烈建议全面查看documentation的安全规则,以了解如何最好地保护您的应用。

答案 1 :(得分:0)

检查您的googleservices.json文件是否在正确的位置。它应该在您的项目> android文件夹>应用程序文件夹>