Firebase 自定义声明允许的数据类型是啥?

Posted

技术标签:

【中文标题】Firebase 自定义声明允许的数据类型是啥?【英文标题】:What are the allowed data types for firebase custom claims?Firebase 自定义声明允许的数据类型是什么? 【发布时间】:2020-10-26 07:02:02 【问题描述】:

我查看了 firebase 文档,发现:

自定义声明对象不应包含任何 OIDC 保留键名或 Firebase 保留名。自定义声明负载不得超过 1000 字节。

这里的自定义声明被称为“自定义声明object”,但我在哪里可以找到将非原始数据类型(int、float、string 等)的值设置为的示例自定义声明(在文档和其他教程中)。现在我很困惑的是 object 指的是整个自定义声明集或单个自定义声明。

简单地说,这是有效的:

admin.auth().setCustomUserClaims(uid, endDate: new Date());

还是一般情况

admin.auth().setCustomUserClaims(uid, 
    key1: 
        sub_key1: value1,
        sub_key2: value2      
    ,
    key2: 
        sub_key1: vlaue1
    
);

如果这无效,有没有办法将时间戳设置为自定义声明,以便我可以在安全规则中使用它来允许基于它的访问。

【问题讨论】:

【参考方案1】:

自定义声明接受任何有效的 JSON。这意味着您只能使用 JSON 类型,即字符串、数字、布尔值、数组、对象。日期无效。相反,您应该存储日期的数字表示。自 epoch 以来通常使用毫秒数,例如您从 Date.now() 获得的。

 endDate: Date.now() 

【讨论】:

以上是关于Firebase 自定义声明允许的数据类型是啥?的主要内容,如果未能解决你的问题,请参考以下文章

Firebase Auth setCustomClaims()不起作用

在可调用函数中使用自定义声明时是不是需要调用 verifyIdToken()? [复制]

自定义声纳规则 - ClassNotFoundException: com.sonar.sslr.api.AstAndTokenVisitor

Firebase 存储身份验证

在扑朔迷离中,如何将Firebase onAuthStateChanged与user.getTokenId()合并以返回流?

元素数超过 SQL 数据透视语句中允许的最大值