A. Qt开发笔记:OpenSSL库介绍、windows上mingw32版本的OpenSSL编译模块化
OpenSSL介绍
OpenSSL是一个开放源代码的软件库,广泛用于互联网安全通信,如网页服务器,它提供SSL和TLS协议以避免数据被窃听,并确认连接方的身份。SSL协议在Internet上提供秘密性传输,成为工业标准,加密数据并在传输过程中防止篡改。
OpenSSL的特点包括:
1. 安全信道特性:数据保密性,信息加密保护数据机密性;数据完整性,校验传输数据是否被篡改;安全验证,使用密钥作为个人标识。
2. 开源特点:OpenSSL由Eric A. Young和Tim J. Hudson自1995年编写,是一个没有太多限制的开放源代码的软件包。它具有跨平台性能,支持Linux、Windows、BSD、Mac、VMS等。
3. 功能:OpenSSL软件包主要功能包括SSL协议库、应用程序以及密码算法库。它提供了密码算法、密钥和证书封装管理功能以及SSL协议,并提供了丰富的应用程序供测试或其它目的使用。
OpenSSL算法包括:
1. 密钥证书管理:提供证书和密钥相关标准的编解码、产生各种公开密钥对和对称密钥的方法、公钥和私钥的编解码以及私钥的加密保护功能。
2. SSL协议:实现了SSLv2、SSLv3和TLSv1.0。
3. 对称加密:提供了8种对称加密算法,包括AES、DES、Blowfish等。
4. 非对称加密:实现了DH算法、RSA算法、DSA算法和椭圆曲线算法。
5. 信息摘要:实现了MD2、MD5、SHA等5种信息摘要算法。
编译OpenSSL
在Windows上编译OpenSSL需要安装msys环境,将qt的mingw和perl拷贝到msys文件夹下,并添加路径。使用config命令配置安装路径和目录,修改Makefile中的Perl变量,然后执行mingw32-make.exe install命令进行编译安装。在配置时可能遇到操作系统类型错误,需要更换为msys1.0。编译过程中可能遇到找不到库定义的问题,解决方法是在配置时加两个参数。编译成功后可以进行测试和文件结构打包,最终获得静态库。
入坑问题解决
在编译OpenSSL过程中,可能会遇到Perl调用失败、操作系统类型错误、编译时找不到库定义等问题。解决方法包括修改顶层Makefile的Perl变量、更换为msys1.0、在配置时加两个参数等。最后执行mingw32-make.exe install命令并打包文件结构以完成编译过程。
B. Qt C++ DES加密ECB模式,Pkcs7或Pkcs5填充有代码吗
Qt是一个跨平台的C++图形用户界面库,提供了许多用于开发图形用户界面应用程序的工具和功能。Qt中内置了许多常用的加密和哈希算法,但是并没有提供直接的DES加密功能。
如果你想在Qt中使用DES加密,你可以使用OpenSSL库中的DES加密功能。下面是一个使用ECB模式和PKCS7填充的DES加密的例子:
#include <QByteArray>
#include <openssl/des.h>
// 加密函数
QByteArray encrypt(const QByteArray &data, const QByteArray &key)
{
// 对称加密算法需要使用秘钥,所以需要将秘钥进行哈希运算得到真正的秘钥
QByteArray realKey = QCryptographicHash::hash(key, QCryptographicHash::Md5);
// 分配内存空间,用于存储加密后的数据
QByteArray result(data.size() + 8, 0);
// 初始化DES加密算法
DES_cblock keyBlock;
memcpy(keyBlock, realKey.constData(), 8);
DES_key_schele schele;
DES_set_key_unchecked(&keyBlock, &schele);
// 设置填充模式为PKCS7
DES_set_padding(DES_PKCS7_PADDING);
// 调用OpenSSL库中的加密函数
DES_ecb_encrypt(reinterpret_cast<const_DES_cblock *>(data.constData()),
reinterpret_cast<DES_cblock *>(result.data()), &schele, DES_ENCRYPT);
return result;
}