当前位置: 首页 > 知识库问答 >
问题:

React js抛出Firestore丢失或权限不足,即使规则是公共的

储峻
2023-03-14

下面是我编写firestore的代码

当我试图写入Firestore数据库时,我得到缺少或权限不足错误。即使在我将规则更改为public之后。

在我的项目中使用npm firebase包的iam

const [progress, setProgress] = useState(0);
const [error, setError] = useState(null);
const [url, setUrl] = useState(null);



useEffect(() => {

    const storageRef = myFirebaseStorage.ref(file.name);

     //database collection reference
    const collectionRef = myFirebaseFirestore.collection('images');

    storageRef.put(file).on('state_changed', (snap) => {

        let percentage = (snap.bytesTransferred / snap.totalBytes) * 100;

        setProgress(percentage);

    },
        (err) => {
            setError(err);
        },
        async () => {

            const url = await storageRef.getDownloadURL();
            console.log(" Image URL: ", url);
            const createdAt = timestamp();

             //writing data to firestore

            collectionRef.add({ url: url, createdAt: createdAt })
                .then((docRef) => {
                    console.log("Document written with ID: ", docRef.id);
                })
                .catch((error) => {
                    console.error("Error adding document: ", error);
                });

                





            collectionRef
                .get()
                .then(snapshot => {
                    // allowed for an admin user
                    console.log("got it ")
                })
                .catch(error => {
                    // a non-admin user is denied list permission
                    console.log(error.message);
                });
            setUrl(url);

        }
    )
}, [file])

return (
    { progress, url, error }
)}export default useStorage

共有1个答案

钱凌
2023-03-14

当您还引用您的Firebase存储时,您还需要设置Firebase存储安全规则,以便写入工作。

 类似资料:
  • 我使用的是Role(允许读,写:如果request.auth.uid!=null),当我登录时,我得到的数据是ok的,但当我注销用户时,我得到的错误是:缺少或不充分的权限。首先,我认为这是因为我没有取消订阅我尝试的可观察的(rxjs/operator/takewhile)即使我使用异步管道,我也得到了同样的错误。

  • 我在自学firestore,我想不出一种方法,只允许用户更新、删除或阅读他们添加的集合。 我使用firebase auth进行用户处理。对于每个集合,我将作为保存在数据库中。 这是我的规矩 当我试图读取/获取数据时,我得到错误。 我正在使用firestore的web api(JavaScript)。这是我用来读取数据的代码。

  • 意向行为 目标是修改我的安全规则,以便只有经过身份验证的用户才能读写该特定用户的数据。这是基于users UID,这是我们如何识别单个用户的(这是通过firebase身份验证完成的,所以不确定问题是什么)。 我的数据库结构 FirebaseError:权限缺失或不足 任何关于我在这里能做什么的建议都将不胜感激。我在其他问题中找不到任何适用的东西。 我的查询 *我的错误

  • 我编写了一些与默认规则完美配合的代码。代码如下: 但如果我用这些规则 我明白了 我做错了什么?

  • 使用以下安全规则: 我的应用程序似乎使用进行了正确的身份验证,因为返回正确的用户ID。 我是不是做错了什么?

  • 我的Firestore数据库有一些用户和一些s。如果没有其他人认领,用户可以认领。他们通过在上创建一个文档来声明,该文档有一个名为的字段,该字段是对他们自己的用户文档的引用。 我想我已经在这些安全规则中捕捉到了: 但是,当为所有权删除文档时,我获得了: 我是这样做的: 如果我打开read和write设置为true的文档,就不会出现此异常。 我的规则怎么了?他们用模拟器测试正常。