当前位置: 首页 > news >正文

Qt 哈希加密之 QCryptographicHash

 【写在前面】

        QCryptographicHash 是 Qt 框架中提供的一个类,它用于实现加密散列函数,也就是我们常说的哈希函数。哈希函数能够将任意长度的数据转换为固定长度的哈希值,这个哈希值通常用于数据的完整性校验、密码存储等场景。

        什么是哈希函数?

        哈希函数是一种单向函数,它可以接收一个输入(或称为消息),然后返回一个固定大小的输出,这个输出就是哈希值。哈希函数具有以下几个特点:

  1. 确定性:相同的输入总是产生相同的输出。
  2. 快速计算:计算哈希值的速度非常快。
  3. 抗篡改性:即使输入数据发生微小的变化,输出的哈希值也会发生显著变化。
  4. 雪崩效应:输入的微小变化会导致输出的显著变化。
  5. 难以逆向:从哈希值几乎不可能逆推出原始输入。

【正文开始】

        QCryptographicHash 主要使用场景如下:

1. 安全性增强

        QCryptographicHash 提供了多种加密哈希算法:MD4MD5、SHA-1、SHA-224、SHA-256SHA-384SHA-512,这些算法被广泛认为是安全的。使用这些哈希算法可以增强应用程序的数据安全性。

2. 数据完整性验证

        在文件传输或存储过程中,数据可能会因为各种原因而遭到篡改。使用 QCryptographicHash 可以生成数据的哈希值,通过比较哈希值来验证数据的完整性。

3. 密码存储

        在用户注册或登录时,直接存储用户密码是不安全的。使用 QCryptographicHash 对密码进行哈希处理,可以安全地存储密码的哈希值,即使数据库被泄露,攻击者也无法直接获取原始密码。

4. 数字签名

        在数字签名中,QCryptographicHash 用于生成消息的摘要,然后使用私钥对摘要进行加密,生成数字签名。接收方可以通过公钥验证签名的有效性,确保消息的来源和完整性。

5. 防止重放攻击

        在某些场景下,比如网络通信,使用 QCryptographicHash 可以生成基于时间戳和数据内容的哈希值,以防止攻击者重放旧的数据包。

        QCryptographicHash 使用方法:

        1、包含头文件:在使用 QCryptographicHash 之前,需要包含相应的头文件 #include <QCryptographicHash>

        2、计算哈希值:

        - 使用静态方法:可以直接调用 QCryptographicHash::hash() 方法,传入待计算哈希值的数据和选择的算法,即可得到哈希值的 QByteArray 表示。

        - 使用对象方法:首先创建 QCryptographicHash 对象,并指定要使用的算法。然后,使用 addData() 方法添加数据,最后调用 result() 方法获取最终的

        示例如下:

#include <QCryptographicHash>  
#include <QByteArray>  
#include <QString>  int main() {  QByteArray byteArray;  byteArray.append("password");  // 使用静态方法计算哈希值  QByteArray hash = QCryptographicHash::hash(byteArray, QCryptographicHash::Md5);  QString strMD5 = hash.toHex(); // 将哈希值转换为十六进制字符串  // 输出哈希值  qDebug() << strMD5; // 输出: 5f4dcc3b5aa765d61d8327deb882cf99  return 0;  
}

【结语】

       注意哈希算法的选择应根据具体的应用场景和安全需求来确定。

        例如,MD5 SHA-1 由于存在安全漏洞,已经不再推荐用于密码存储等安全敏感的场景。 哈希值是不可逆的,即不能通过哈希值恢复原始数据。 不同的哈希算法在输出长度、计算速度和安全性等方面存在差异,开发时应根据实际需求进行选择。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 泛微OA流程接口调用工具类
  • SpringBoot的Web开发
  • 护眼大路灯哪个牌子好?公认五款最好护眼大路灯分享
  • C++ 特性之vector详解 + 联合opencv使用
  • 数据库方式实现实时排行榜
  • http参数污染利用php小特性绕过贷齐乐waf
  • Dom 元素转换 Image 图片 (截图)
  • 探索PHP的心脏:流行CMS系统全解析
  • KillWxapkg 自动化反编译微信小程序,小程序安全评估工具,发现小程序安全问题,自动解密,解包,可还原工程目录,支持修改Hook,小程序
  • html复习
  • 大语言模型面试宝典:30+ 必考问题与答案,助你一臂之力
  • 关于100个linux常用的命令
  • 2-63 基于matlab的GMPHD滤波器算法
  • 互联网摸鱼日报(2024-08-13)
  • Java Nacos与Gateway的使用
  • 2017届校招提前批面试回顾
  • Bytom交易说明(账户管理模式)
  • Date型的使用
  • iBatis和MyBatis在使用ResultMap对应关系时的区别
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • Javascript编码规范
  • LeetCode541. Reverse String II -- 按步长反转字符串
  • mockjs让前端开发独立于后端
  • python学习笔记-类对象的信息
  • Quartz初级教程
  • Tornado学习笔记(1)
  • 阿里云前端周刊 - 第 26 期
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 码农张的Bug人生 - 初来乍到
  • 思维导图—你不知道的JavaScript中卷
  • 提醒我喝水chrome插件开发指南
  • 微信开源mars源码分析1—上层samples分析
  • - 转 Ext2.0 form使用实例
  • 自制字幕遮挡器
  • ​ 全球云科技基础设施:亚马逊云科技的海外服务器网络如何演进
  • ​MySQL主从复制一致性检测
  • ​探讨元宇宙和VR虚拟现实之间的区别​
  • ​香农与信息论三大定律
  • #define、const、typedef的差别
  • #if 1...#endif
  • #QT(TCP网络编程-服务端)
  • $(this) 和 this 关键字在 jQuery 中有何不同?
  • $.ajax()
  • (06)金属布线——为半导体注入生命的连接
  • (52)只出现一次的数字III
  • (C11) 泛型表达式
  • (html5)在移动端input输入搜索项后 输入法下面为什么不想百度那样出现前往? 而我的出现的是换行...
  • (多级缓存)多级缓存
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)spring boot校园健康监测管理系统 毕业设计 151047
  • (附源码)springboot掌上博客系统 毕业设计063131
  • (过滤器)Filter和(监听器)listener
  • (剑指Offer)面试题34:丑数
  • (剑指Offer)面试题41:和为s的连续正数序列
  • (学习日记)2024.03.25:UCOSIII第二十二节:系统启动流程详解