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;
}