Qt下使用AES进行字符串加密解密

文章目录

  • 前言
  • 一、获取QAESEncryption库
  • 二、加密与解密实现
  • 三、示例完整代码
  • 四、下载链接
  • 总结


前言

引用:AES(Advanced Encryption Standard)是一种对称加密算法,被广泛用于数据加密,提供128、192、256位三种密钥长度,分别对应AES-128、AES-192和AES-256。Qt作为一个跨平台的C++图形用户界面应用程序开发框架,也支持AES加密,通常通过第三方库实现。

本文将介绍如何在Qt环境下调用第三方库使用AES对字符串进行加密和解密,并结合相应的示例进行讲解,以便大家学习,如有错误之处,欢迎大家批评指正。

项目效果
在这里插入图片描述


提示:以下是本篇文章正文内容,下面案例可供参考

一、获取QAESEncryption库

从GitHub或其他可靠来源获取QAESEncryption库,比如Qt-AES,也可以通过下文我的百度网盘链接进行下载,将QAESEncryption库的头文件和源文件(qaesencryption.h和qaesencryption.cpp)添加到项目中:

如图是我的示例代码结构:
在这里插入图片描述

我的示例AESTest.pro如下:

QT       += core guigreaterThan(QT_MAJOR_VERSION, 4): QT += widgetsCONFIG += c++11DEFINES += QT_DEPRECATED_WARNINGS#设置字符
contains( CONFIG,"msvc" ):QMAKE_CXXFLAGS += /source-charset:utf-8 /execution-charset:utf-8
contains( CONFIG,"msvc" ):QMAKE_CFLAGS +=/source-charset:utf-8 /execution-charset:utf-8SOURCES += \main.cpp \widget.cpp \qaesencryption.cppHEADERS += \widget.h \qaesencryption.hFORMS += \widget.ui# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

二、加密与解密实现

QAESEncryption源码添加好后,实际使用起来就比较简单了,示例代码中有详细介绍:

//加密
void Widget::on_pb_encode_clicked()
{//填充输入内容和密钥QString strData = ui->le_input->text();QString strKey = ui->le_key->text();QString strEncoded = EncodedText(strData,strKey);//拼接随机字符和加密后的字符//字符数组chars内这些字符将作为生成随机字符串的候选字符QString result;const char chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";const int size = sizeof(chars) - 1;for(int i=0;i<20;i++){//生成一个长度为20的随机字符串int index = QRandomGenerator::global()->bounded(size);result.append(chars[index]);}//将拼接的字符显示在界面上并保存为文件,同一内容多次点击加密,可以看到显示的内容中前面的随机字符会变化QString saveEncoded = result + strEncoded;ui->te_encodeShow->setText(saveEncoded);QString exePath = QCoreApplication::applicationDirPath();QString encodedFileName = exePath + "/EncodedFile.txt";saveEncodedFile(encodedFileName,saveEncoded);}//解密
void Widget::on_pb_decode_clicked()
{//获取加密内容及密钥QString strKey = ui->le_key->text();QString strDecoded = "";
#if 0//直接赋值加密显示内容strDecoded = ui->te_encodeShow->toPlainText();
#else//读取加密文件,注意与加密时保存的文件一致QString exePath = QCoreApplication::applicationDirPath();QString encodedFileName = exePath + "/EncodedFile.txt";QFile file(encodedFileName);if(file.open(QIODevice::ReadOnly | QIODevice::Text)){QTextStream in(&file);in.setCodec("UTF-8");strDecoded = in.readAll();   //读取文件内容file.close();}
#endif//截取字符串strDecoded中从第20个字符开始到末尾的部分,注意与加密时添加的随机字符数要对应strDecoded = strDecoded.mid(20);//密钥需要与加密时的一致,如果密钥不对,解密显示会乱码QString decoded = DecodedText(strDecoded,strKey);ui->te_decodeShow->setText(decoded);
}

三、示例完整代码

1.widget.h

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QRandomGenerator>
#include <QCryptographicHash>
#include <QProcess>
#include <QFile>
#include <QDebug>#include "qaesencryption.h"QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();void initWidget();QString EncodedText(QString data,QString key);QString DecodedText(QString data,QString key);void saveEncodedFile(QString fileName,QString fileData);private slots:void on_pb_encode_clicked();void on_pb_decode_clicked();private:Ui::Widget *ui;
};
#endif // WIDGET_H

2.widget.cpp

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);this->initWidget();
}Widget::~Widget()
{delete ui;
}//初始化界面
void Widget::initWidget()
{//指定尺寸及禁用最大化setFixedSize(500,360);setWindowFlags(windowFlags() & ~Qt::WindowMaximizeButtonHint);//设置只读ui->te_encodeShow->setReadOnly(true);ui->te_decodeShow->setReadOnly(true);
}//使用AES对数据进行加密
QString Widget::EncodedText(QString data, QString key)
{//密钥长度AES_128,加密方式ECB,填充方式ZEROQAESEncryption encryption(QAESEncryption::AES_128, QAESEncryption::ECB, QAESEncryption::ZERO);//对钥匙进行QCryptographicHash加密QByteArray hashKey = QCryptographicHash::hash(key.toUtf8(), QCryptographicHash::Sha1);//对源数据加密QByteArray encodedText = encryption.encode(data.toUtf8(), hashKey);//QByteArray转QString (toBase64()不能去掉)QString encodeTextStr = QString::fromLatin1(encodedText.toBase64());//qDebug()<< "encodedText:"<< encodeTextStr;return encodeTextStr;
}//使用AES对数据进行解密
QString Widget::DecodedText(QString data, QString key)
{//密钥长度AES_128,加密方式ECB,填充方式ZEROQAESEncryption encryption(QAESEncryption::AES_128, QAESEncryption::ECB, QAESEncryption::ZERO);//对钥匙进行QCryptographicHash加密QByteArray hashKey = QCryptographicHash::hash(key.toUtf8(), QCryptographicHash::Sha1);//解密QByteArray decodedText = encryption.decode(QByteArray::fromBase64(data.toLatin1()), hashKey);//QByteArray转QStringQString decodedTextStr = QString::fromLatin1(decodedText);//qDebug()<<"decodedText:"<< decodedTextStr;return decodedTextStr;
}//保存为文件
void Widget::saveEncodedFile(QString fileName,QString fileData)
{//将文本保存为文件QFile file(fileName);if(file.open(QIODevice::WriteOnly | QIODevice::Text)){QTextStream out(&file);out.setCodec("UTF-8");out << fileData;   //写入加密内容到文件file.close();}else{//处理文件打开失败的情况qDebug()<<fileName<<"打开失败!";}
}//加密
void Widget::on_pb_encode_clicked()
{//填充输入内容和密钥QString strData = ui->le_input->text();QString strKey = ui->le_key->text();QString strEncoded = EncodedText(strData,strKey);//拼接随机字符和加密后的字符//字符数组chars内这些字符将作为生成随机字符串的候选字符QString result;const char chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";const int size = sizeof(chars) - 1;for(int i=0;i<20;i++){//生成一个长度为20的随机字符串int index = QRandomGenerator::global()->bounded(size);result.append(chars[index]);}//将拼接的字符显示在界面上并保存为文件,同一内容多次点击加密,可以看到显示的内容中前面的随机字符会变化QString saveEncoded = result + strEncoded;ui->te_encodeShow->setText(saveEncoded);QString exePath = QCoreApplication::applicationDirPath();QString encodedFileName = exePath + "/EncodedFile.txt";saveEncodedFile(encodedFileName,saveEncoded);}//解密
void Widget::on_pb_decode_clicked()
{//获取加密内容及密钥QString strKey = ui->le_key->text();QString strDecoded = "";
#if 0//直接赋值加密显示内容strDecoded = ui->te_encodeShow->toPlainText();
#else//读取加密文件,注意与加密时保存的文件一致QString exePath = QCoreApplication::applicationDirPath();QString encodedFileName = exePath + "/EncodedFile.txt";QFile file(encodedFileName);if(file.open(QIODevice::ReadOnly | QIODevice::Text)){QTextStream in(&file);in.setCodec("UTF-8");strDecoded = in.readAll();   //读取文件内容file.close();}
#endif//截取字符串strDecoded中从第20个字符开始到末尾的部分,注意与加密时添加的随机字符数要对应strDecoded = strDecoded.mid(20);//密钥需要与加密时的一致,如果密钥不对,解密显示会乱码QString decoded = DecodedText(strDecoded,strKey);ui->te_decodeShow->setText(decoded);
}

3.widget.ui
在这里插入图片描述

四、下载链接

我的示例百度网盘链接:https://pan.baidu.com/s/1NJslzHqOYw35VnnbrVodDw?pwd=xxcj
提取码:xxcj


总结

通过调用QAESEncryption库,我们可以方便地在Qt项目中实现AES加密和解密功能,本文示例中还增加了加密数据保存为文件的功能,这些也是Qt的基础,最主要的还是跟之前所讲的一样,要学会使用大佬们造好的轮子呀~


hello:
共同学习,共同进步,如果还有相关问题,可在评论区留言进行讨论。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/891107.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker 安装minio

docker pull minio/minio #启动 mkdir -p /root/minio/config mkdir -p /root/minio/datadocker run -d \--name minio \-p 9002:9000 \-p 9001:9001 \--restartalways \-v /root/minio/data:/data \-v /root/minio/config:/root/.minio \-e "MINIO_ACCESS_KEYminioadmin…

Linux系统下安装配置 Nginx 超详细图文教程

一、下载Nginx安装包 nginx官网&#xff1a;nginx: download[这里是图片001]http://nginx.org/en/download.html 找到我们所需要版本&#xff0c;把鼠标移动到上面&#xff0c;右键打开链接进行下载 或者如果Linux联网&#xff0c;直接在Linux服务上使用wget命令把Nginx安装包…

爬虫与反爬虫实现全流程

我选取的网页爬取的是ppt nba版 需要的工具:pycharm,浏览器 爬虫需要观察它的网页信息,然后开始首先爬取它的html,可以看到有人气,标题,日期,咨询 可以看到用get方法 import requests url"https://img-home.csdnimg.cn/images/20230724024159.png?origin_urlhttps%3A%2…

最新版Edge浏览器加载ActiveX控件技术——alWebPlugin中间件V2.0.28-迎春版发布

allWebPlugin简介 allWebPlugin中间件是一款为用户提供安全、可靠、便捷的浏览器插件服务的中间件产品&#xff0c;致力于将浏览器插件重新应用到所有浏览器。它将现有ActiveX控件直接嵌入浏览器&#xff0c;实现插件加载、界面显示、接口调用、事件回调等。支持Chrome、Firefo…

OSPFv2协议状态切换(状态机)基本原理-RFC2328

个人认为&#xff0c;理解报文就理解了协议。通过报文中的字段可以理解协议在交互过程中相关传递的信息&#xff0c;更加便于理解协议。 自动换行 OSPFv2&#xff1a; 关于 OSPFv2 协议基本原理&#xff0c;可参考RFC2328-OSPF Version 2。 其他相关资料可参考&#xff1a; …

【最新】沃德协会管理系统源码+uniapp前端+环境教程

一.系统介绍 一款基于FastAdminThinkPHPUniapp开发的商协会系统&#xff0c;新一代数字化商协会运营管理系统&#xff0c;以“智慧化会员体系、智敏化内容运营、智能化活动构建”三大板块为基点&#xff0c;实施功能全场景覆盖&#xff0c;一站式解决商协会需求壁垒&#xff0…

【LeetCode: 83. 删除排序链表中的重复元素 + 链表】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

算法练习——模拟题

前言&#xff1a;模拟题的特点在于没有什么固定的技巧&#xff0c;完全考验自己的代码能力&#xff0c;因此有助于提升自己的代码水平。如果说一定有什么技巧的话&#xff0c;那就是有的模拟题能够通过找规律来简化算法。 一&#xff1a;替换所有问号 题目要求&#xff1a; 解…

Idea创建JDK17的maven项目失败

Idea创建JDK17的maven项目失败 Error occurred during initialization of VM Could not find agent library instrument on the library path, with error: Can’t find dependent libraries Possible solution: Check your maven runner VM options. Open Maven Runner setti…

VSCode设置Playwright教程

1.安装扩展 打开VS Code&#xff0c;在扩展—>搜索"Playwright Test for VSCode"&#xff0c;点击安装 按快捷键CommandShiftP&#xff0c;输入install playwright&#xff0c;点击安装Playwright 安装成功会有如下提示 2.调试脚本 打开tests/example.spec.ts文…

HTML新特性|01 音频视频

音频 1、Audio (音频) HTML5提供了播放音频文件的标准 2、control(控制器) control 属性供添加播放、暂停和音量控件 3、标签: <audio> 定义声音 <source> 规定多媒体资源,可以是多个<!DOCTYPE html> <html lang"en"> <head><…

【深度学习】卷积网络代码实战ResNet

ResNet (Residual Network) 是由微软研究院的何凯明等人在2015年提出的一种深度卷积神经网络结构。ResNet的设计目标是解决深层网络训练中的梯度消失和梯度爆炸问题&#xff0c;进一步提高网络的表现。下面是一个ResNet模型实现&#xff0c;使用PyTorch框架来展示如何实现基本的…

雷电「模拟器」v9 最新清爽去广

前言 雷电模拟器9是基于安卓9内核开发的全新版本模拟器 安装环境 [名称]&#xff1a;雷电「模拟器」 [大小]&#xff1a;579MB [版本]&#xff1a;9.1.34 [语言]&#xff1a;简体中文 [安装环境]&#xff1a;Windows 通过网盘分享的文件&#xff1a;雷电模拟器 链接:…

大模型 API 接入初探

文章目录 大模型 API 接入初探一、使用大模型 API 的前置步骤&#xff08;一&#xff09;注册账户与获取凭证&#xff08;二&#xff09;理解 API 文档 二、三个常用 API&#xff08;一&#xff09;列出模型&#xff08;二&#xff09;FIM 补全&#xff08;三&#xff09;对话补…

实时在线翻译谷歌插件

Real - time Translation插件的安装 1、下载插件并解压 2、打开谷歌浏览器&#xff0c;在地址栏输入 “chrome://extensions/” 进入扩展程序页面. 3、开启页面右上角的 “开发者模式”. 4、点击 “加载已解压的扩展程序” 按钮&#xff0c;选择之前解压的文件夹&#xff0c;点…

[数据集][图像分类]常见鱼类分类数据集2w张8类别

数据集类型&#xff1a;图像分类用&#xff0c;不可用于目标检测无标注文件 数据集格式&#xff1a;仅仅包含jpg图片&#xff0c;每个类别文件夹下面存放着对应图片 图片数量(jpg文件个数)&#xff1a;7554&#xff08;剩余1w多为测试集&#xff09; 分类类别数&#xff1a;…

uniapp开发小程序内嵌h5页面,video视频两边有细小黑色边框

1.问题如图 2.原因分析 是否为设置上述属性呢&#xff1f; 设置了&#xff0c;但是仍然有黑边。经过选中页面元素分析后&#xff0c;判断video元素本身就有这种特点&#xff0c;就是视频资源无法完全铺满元素容器。 3.解决方案

【SpringMVC】SpringMVC 快速入门

通常&#xff0c;Web 应用的工作流程如下&#xff1a; 用户通过浏览器访问前端页面&#xff1b; 前端页面通过异步请求向后端服务器发送数据&#xff1b; 后端采用“表现层-业务层-数据层”三层架构进行开发&#xff1a; 表现层接收页面请求将请求参数传递给业务层业务层访问…

OpenGL变换矩阵和输入控制

在前面的文章当中我们已经成功播放了动画&#xff0c;让我们的角色动了起来&#xff0c;这一切变得比较有意思了起来。不过我们发现&#xff0c;角色虽然说是动了起来&#xff0c;不过只是在不停地原地踏步而已&#xff0c;而且我们也没有办法通过键盘来控制这个角色来进行移动…

【Spring MVC 核心机制】核心组件和工作流程解析

在 Web 应用开发中&#xff0c;处理用户请求的逻辑常常会涉及到路径匹配、请求分发、视图渲染等多个环节。Spring MVC 作为一款强大的 Web 框架&#xff0c;将这些复杂的操作高度抽象化&#xff0c;通过组件协作简化了开发者的工作。 无论是处理表单请求、生成动态页面&#x…