Qt下图片加密的两种方式

目录

Base64加密

Base64加密

Base64解密 

异或加密

测试

Base64加密

Base64解密 

异或加密 

异或解密 

最后


 

Base64加密

Base64加解密密主要用Qt的两个函数,即

QByteArray QByteArray::toBase64() const
QByteArray QByteArray::fromBase64(const QByteArray & base64) [static]

下面自己封装两个函数,一个加密,一个解密。

Base64加密

/***************************************************************
	FunctionName:	EncryptAndSaveJPG
	Purpose:		加载图片,Base64加密后保存,并返回加密后的图片数据
	Parameter:		
					1 btImage [QByteArray, OUT]
						加密的图片数据
					2 fullPath [QString, IN]
						图片的全路径
	Return:			return true if sucess,else return false
	Remark:      	NULL
****************************************************************/
bool EncryptAndSaveJPG(QByteArray& btImage, QString fullPath)
{
	QFile file(fullPath);
	if (!file.open(QFile::WriteOnly))
	{
		QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
			QString::fromLocal8Bit("不能写文件 %1:\n%2.")
			.arg(fullPath)
			.arg(file.errorString()));
		return false;
	}

	//加密
	QByteArray encryImag = btImage.toBase64();
	file.write(encryImag);
	file.close();
	return true;
}

Base64解密 

/***************************************************************
	FunctionName:	LoadJPGAndDecrpt
	Purpose:		加载图片,Base64解密,并返回解密后的图片数据
	Parameter:		
					1 btImage [QByteArray, OUT]
						解密的图片数据
					2 filefullPath [QString, IN]
						图片的全路径
	Return:			return true if sucess,else return false
	Remark:      	NULL
****************************************************************/
bool LoadJPGAndDecrpt(QByteArray& btImage, QString filefullPath)
{
	QFile file(filefullPath);
	if (!file.open(QFile::ReadOnly))
	{
		QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
			QString::fromLocal8Bit("不能读取文件 %1:\n%2.")
			.arg(filefullPath)
			.arg(file.errorString()));
		return false;
	}

	btImage = QByteArray::fromBase64(file.readAll());
	file.close();
	return true;
}

异或加密

异或加解密一个函数就可以搞定。即将待加密/解密的图片的每一个字节与0xff异或。

/***************************************************************
	FunctionName:	XorEncryAndDecry
	Purpose:		将图片数据与key值异或,key一般取0xff
	Parameter:		
					1 QByteArray [QByteArray, IN]
						待加/解密的图片数据
					2 btImageOut [QByteArray, OUT]
						加/解密后的图片数据
                    3 key [const char, INT]
                        键值
	Return:			NULL
	Remark:      	NULL
****************************************************************/
void XorEncryAndDecry(QByteArray& btImageIn, QByteArray& btImageOut, const char &key)
{
	for (int i = 0; i < btImageIn.size(); i++)
	{
		btImageOut[i] = btImageIn[i] ^ key;
	}
}

测试

下面调用测试一下,可以弹出对话框选取文件。

Base64加密

void encry_Slot()
{
	QString filePath = QFileDialog::getOpenFileName(this);
	if (filePath.isEmpty())
	{
		return;
	}


	QFile read_file(filePath);
	if (!read_file.open(QIODevice::ReadOnly))
	{
		QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("文件读取失败!"));
		return;
	}

	QByteArray btImage = read_file.readAll();
	bool bResult = EncryptAndSaveJPG(btImage, filePath);
	if (bResult)
	{
		QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("加密完成!"));
	}
}

Base64解密 

void decry_Slot()
{
	QString fileName = QFileDialog::getOpenFileName(this);
	QByteArray btImage;
	if (!fileName.isEmpty())
	{
		bool bResult = LoadJPGAndDecrpt(btImage, fileName);
		if (bResult)
		{
			QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("解密完成!"));
		}

		//保存解密后的图片
		QFile file(fileName);
		if (!file.open(QFile::WriteOnly))
		{
			QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
				QString::fromLocal8Bit("不能写文件 %1:\n%2.")
				.arg(fileName)
				.arg(file.errorString()));
			return;
		}

		file.write(btImage);
		file.close();
	}
}

异或加密 

void encryXor_Slot()
{
	QString filePath = QFileDialog::getOpenFileName(this);
	if (filePath.isEmpty())
	{
		return;
	}


	QFile read_file(filePath);
	if (!read_file.open(QIODevice::ReadOnly))
	{
		QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("文件读取失败!"));
		return;
	}

	QByteArray btImage = read_file.readAll();
	QByteArray btImageXor;
	XorEncryAndDecry(btImage, btImageXor, 0xff);
	
	QFile write_file(filePath);
	if (!write_file.open(QFile::WriteOnly))
	{
		QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
			QString::fromLocal8Bit("不能写文件 %1:\n%2.")
			.arg(filePath)
			.arg(write_file.errorString()));
		return;
	}

	//加密
	write_file.write(btImageXor);
	read_file.close();
	write_file.close();
	QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("加密完成!"));

}

异或解密 

void decryXor_Slot()
{
	QString fileName = QFileDialog::getOpenFileName(this);
	if (fileName.isEmpty())
	{
		return;
	}

	QFile file(fileName);
	if (!file.open(QFile::ReadOnly))
	{
		QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
			QString::fromLocal8Bit("不能读取文件 %1:\n%2.")
			.arg(fileName)
			.arg(file.errorString()));
		return;
	}

	QByteArray btImageXor = file.readAll();
	QByteArray btImage;
	XorEncryAndDecry(btImageXor, btImage, 0xff);

	//保存解密后的图片
	QFile write_file(fileName);
	if (!write_file.open(QFile::WriteOnly))
	{
		QMessageBox::warning(this, QString::fromLocal8Bit("提示"),
			QString::fromLocal8Bit("不能写文件 %1:\n%2.")
			.arg(fileName)
			.arg(write_file.errorString()));
		return;
	}


	write_file.write(btImage);
	write_file.close();
	file.close();
	
	QMessageBox::warning(this, QStringLiteral("提示"), QStringLiteral("解密完成!"));
}

最后

测试发现,解密后的图片与原图大小一致,且每一个字节数据都一致。

测试程序地址:https://download.csdn.net/download/qq_24282081/11295479

mfc下Base64加解密文件请看:

https://blog.csdn.net/qq_24282081/article/details/100527570

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt 是一个跨平台的应用程序开发框架,采用 C++ 编写。DES(Data Encryption Standard)是一种对称加密算法,用于保护数据的机密性。 要在 Qt 中实现 DES 加密的 socket 通信,可以按照以下步骤进行: 1. 导入所需的库:包括 `QTcpSocket` 用于建立 socket 通信,`QDataStream` 用于数据的传输和序列化,以及 `QMessageBox` 用于显示错误信息。 2. 创建一个 `QTcpServer` 对象并监听指定的主机和端口。当有客户端连接时,`newConnection()` 信号将会触发。 3. 在 `newConnection()` 信号的槽函数中,通过 `nextPendingConnection()` 获取连接的套接字。然后,使用 `setSocketDescriptor()` 将套接字设置给一个 `QTcpSocket` 对象。 4. 在 `QTcpSocket` 的 `readyRead()` 信号的槽函数中,当套接字有数据可读时,将读取的数据保存,并进行解密操作。可以使用 DES 相关的库函数或者自行实现 DES 解密算法。 5. 在 `QTcpSocket` 的 `bytesWritten(qint64 bytes)` 信号的槽函数中,当数据成功写入套接字时,显示已发送的字节数。 6. 客户端发送数据时,使用 `QTcpSocket` 对象的 `write()` 函数将要发送的数据写入套接字,发送给服务器。 7. 最后,创建一个 `QTcpSocket` 对象并调用 `connectToHost()` 连接到服务器的主机和端口。 通过按照上述步骤实现,可以在 Qt 中实现 DES 加密的 socket 通信。 ### 回答2: Qt 是一个跨平台的应用程序框架,可以用来开发各种类型的应用程序,包括网络通信应用。而 DES(Data Encryption Standard)是一种对称加密算法,可以用来对数据进行加密和解密。 要在 Qt 中实现 DES 加密的 Socket 通信,可以按照以下步骤: 1. 导入 Qt 相关的网络通信类:在代码中导入 `QTcpSocket` 和 `QTcpServer` 类,这两个类提供了 TCP/IP socket 通信的功能。 2. 创建 TCP 服务器:使用 `QTcpServer` 类创建一个 TCP 服务器,并绑定到特定的 IP 地址和端口。 3. 监听客户端连接请求:在服务器端调用 `listen` 函数,开始监听客户端的连接请求。一旦有客户端请求连接,服务器将会触发 `newConnection` 信号。 4. 接受客户端连接:在 `newConnection` 信号的槽函数中,使用 `nextPendingConnection` 函数接受客户端的连接请求,并返回一个新的 `QTcpSocket` 对象,这个对象用于和客户端进行通信。 5. 实现 DES 加密算法:使用 DES 算法对需要传输的数据进行加密和解密。Qt 没有提供 DES 算法的实现,可以调用第三方的加密库,例如 OpenSSL。 6. 客户端发送加密数据:在客户端中创建一个 `QTcpSocket` 对象,并连接到服务器的 IP 地址和端口。然后,将需要传输的数据使用 DES 算法加密,并通过 `write` 函数将加密后的数据发送给服务器端。 7. 服务器端接收并解密数据:在服务器端的 `QTcpSocket` 对象中,使用 `readyRead` 信号和对应的槽函数,实现接收客户端发送的加密数据。然后,对接收到的数据使用 DES 算法进行解密,并处理解密后的数据。 8. 客户端接收服务器响应:在客户端中,使用 `readyRead` 信号和对应的槽函数,实现接收服务器端发送的响应。同样,对接收到的加密数据,使用 DES 算法进行解密,并处理解密后的数据。 通过以上步骤,就可以在 Qt 中实现 DES 加密的 Socket 通信。其中,需要注意的是实现 DES 加密算法的部分可能需要调用第三方的加密库来实现。 ### 回答3: Qt是一个跨平台的应用程序开发框架,可以用来实现各种各样的应用程序,包括加密通信。 DES(Data Encryption Standard)是一种对称密钥加密算法,可以用来对通信数据进行加密。在Qt中,可以使用QCryptographicHash类来实现DES加密。 首先,需要导入QCryptographicHash和QTcpSocket类库: #include <QCryptographicHash> #include <QTcpSocket> 接下来,创建一个QTcpSocket对象,并连接到服务器: QTcpSocket *socket = new QTcpSocket(); socket->connectToHost("服务器地址", 端口号); 然后,可以将待加密的数据转换为QByteArray类型,并使用QCryptographicHash类的hash()函数进行加密: QByteArray data = "需要加密的数据"; QCryptographicHash hash(QCryptographicHash::Md5); //选择加密算法为DES hash.addData(data); //将数据添加到加密算法中 QByteArray encrypted = hash.result().toHex(); //获取加密结果,并转换为16进制表示的ByteArray 最后,将加密后的数据发送给服务器: socket->write(encrypted); 在接收到服务器返回的数据后,可以使用同样的方法解密数据: QByteArray receivedData = socket->readAll(); QCryptographicHash decrypt(QCryptographicHash::Md5); decrypt.addData(receivedData); QByteArray decrypted = decrypt.result().toHex(); 这样就完成了使用Qt实现DES加密socket通信的过程。需要注意的是,这只是一种简单的示例,并没有考虑到网络安全性和加密解密的正确性,实际使用时需要根据具体的需求进行调整和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值