python - 将用户导入 Firebase 时密码错误(使用 SHA256 的 password_hash)

标签 python firebase firebase-authentication firebase-admin

我们正在使用 SHA256 哈希密码将用户从外部数据库迁移到 Firebase Auth。

我们目前正在尝试 from firebase_admin import auth 来导入用户。我们能够导入示例用户,但无法使用该用户登录(密码错误)。

以下是重现该问题的最少代码片段。

  1. 我们以一个用户为例
  2. 我们使用 sha256 来散列密码
  3. 运行 import_users_to_firebase()
  4. 尝试使用示例用户登录 -> 密码无效

`

def hash_password(raw_password):
    import base64
    import hashlib
    algo = hashlib.sha256()
    algo.update(raw_password)
    return base64.b64encode(algo.digest())

def create_mock_user_data():
    email = 'test@example.com'
    password = 'test@example.com'
    password_hash = hash_password(password)
    print 'password_hash: {}'.format(password_hash)
    return email, password_hash


def import_users_to_firebase():
    mock_email, mock_password_hash = create_mock_user_data()
    users = [
        auth.ImportUserRecord(
            uid='someuid',
            display_name='Test example',
            email=mock_email,
            email_verified=False,
            password_hash=b'{}'.format(mock_password_hash),
        ),
        # users list can contain up to 1000 records
    ]
    hash_alg = auth.UserImportHash.sha256(rounds=0)
    result = auth.import_users(users, hash_alg=hash_alg)

    print('Successfully imported {0} users. Failed to import {1} users.'.format(
    result.success_count, result.failure_count))

    for err in result.errors:
        print('Failed to import {0} due to {1}'.format(
            users[err.index].uid, err.reason))

`

我是不是遗漏了什么或误解了什么?

有没有一种方法可以检查 password_hash 是否正确导入?或者有没有一种方法可以配置 Firebase 使用的哈希算法,以便导入的密码与示例用户登录相匹配?

最佳答案

非常感谢 Firebase 支持团队,我的问题得到了解决:) 诀窍是不要在 hash_password() 中进行 base64 编码或之后对其进行解码,因此它是原始字节序列。那就是

auth.ImportUserRecord(
    uid='someuid',
    display_name='Test example',
    email=mock_email,
    email_verified=False,
    password_hash=mock_password_hash, # <-- mock_password_hash is not base64 encoded
)

关于python - 将用户导入 Firebase 时密码错误(使用 SHA256 的 password_hash),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53594248/

相关文章:

python - 使用 ManyToManyField 时如何从数据库中适本地选择条目?

python - 将行数据从文本文件复制到另一列描述中

android - 为什么我的数据库不起作用,我在官方文档中使用的方式?

javascript - 在 Geofire 中使用 Promise

javascript - Firebase 身份验证 - 将用户从 SQL 迁移到 Firebase

reactjs - 如何在 firebase.auth().currentUser 上异步/等待?

python - 模拟在 Python 2.7 中访问时引发异常的可订阅属性的正确方法是什么?

python - groupby pandas 的 concat 结果

java - 如何正确显示 Cloud Firestore 列表的日期?

android - RxJava : how to return the correct type of null