简述
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,可以去找相应的工具进行验证!