21、Qt 之 QCryptographicHash

简述

QCryptographicHash类提供了生成密码散列的方法。该类可以用于生成二进制或文本数据的加密散列值。目前支持MD4、MD5、SHA-1、SHA-224、SHA-256、SHA-384和SHA-512。

共有类型

枚举QCryptographicHash::Algorithm:
常量     取值     描述
QCryptographicHash::Md4     0     生成一个MD4散列
QCryptographicHash::Md5     1     生成一个MD5散列
QCryptographicHash::Sha1     2     生成一个SHA-1散列
QCryptographicHash::Sha224     3     生成一个SHA-224散列(SHA-2)
QCryptographicHash::Sha256     4     生成一个SHA-256散列(SHA-2)
QCryptographicHash::Sha384     5     生成一个SHA-384散列(SHA-2)
QCryptographicHash::Sha512     6     生成一个SHA-512散列(SHA-2)
QCryptographicHash::Sha3_224     7     生成一个SHA3-224散列
QCryptographicHash::Sha3_256     8     生成一个SHA3-256散列
QCryptographicHash::Sha3_384     9     生成一个SHA3-384散列
QCryptographicHash::Sha3_512     10     生成一个SHA3-512散列

公共函数

    void addData(const char * data, int length)
    将第一个字符长度的数据添加到密码散列。

    bool addData(QIODevice * device)
    从开放的QIODevice设备读取数据,直到结束并计算出哈希值。如果成功读取,返回true。

    void addData(const QByteArray & data)
    这个函数重载了addData()。

    void reset()
    重置对象。

    QByteArray result() const
    获取最终的哈希值。

静态公共函数

  • QByteArray hash(const QByteArray & data, Algorithm method)
    获取data数据的哈希值。

示例

通过静态hash()方法计算:

QByteArray byteArray;
byteArray.append("password");
QByteArray hash = QCryptographicHash::hash(byteArray, QCryptographicHash::Md5);
QString strMD5 = hash.toHex();

通过result()方法计算:

QByteArray byteArray;
byteArray.append("password");
QCryptographicHash hash(QCryptographicHash::Md5);
hash.addData(byteArray);  // 添加数据到加密哈希值
QByteArray result = hash.result();  // 返回最终的哈希值
QString strMD5 = result.toHex();

md5值:5f4dcc3b5aa765d61d8327deb882cf99,可以去找相应的工具进行验证!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Chiang木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值