㈠ Bitcoin-qt客戶端加密了,如何導入導出私鑰拜託各位大神
一、Bitcoin-qt客戶端加密後如需要導出某一地址對應的私鑰,需要先調用 walletpassphrase 密碼 解鎖持續時間(秒),如:walletpassphrase h123456789*/* 120,注意留有英文空格。phrase為短語的意思。 然後 mpprivkey 地址 如:mpprivkey (33位公鑰,字母區分大小寫、數混合字) 就可以得到諸如: (52位私鑰,字母區分大小寫、數字混合)二、Bitcoin-qt客戶端沒有加密如需要導出某一地址對應的私鑰,直接在RPC 控制台輸入mpprivkey 地址就可以。多多試幾個地址,你就可以知道,公鑰和私鑰都是成對使用的。一個公鑰對應一個私鑰。數據被Bitcoin-QT發送出去之前,需要兩層加密,第一層是隨機用某個公鑰對應的私鑰來加密數據,然後把這個公鑰明文發送給收款方。收款方使用這個公鑰打開對應私鑰加密的數據,這樣就可以確保數據是付款方發送。 第二層是用收款方的公鑰(其實就是33位的收款地址)來加密。經過這次加密後,只有掌握這個公鑰對應私鑰的人,才能收到這筆錢。猜測,Bitcoin 錢包文件wallet.dat裡面保存的應該是一對對的公鑰和私鑰。公鑰和私鑰一一對應。另外,可能出於安全性的考慮,Bitcoin-QT在加密錢包後是不能去掉密碼的。 如要去掉密碼,可以創建一個新錢包,然後把私鑰導入到新錢包里去。 使用命令:importprivkey 私鑰 私鑰導入後,Bitcoin-QT會在「接收」窗口自動顯示對應的地址(公鑰)。而如果這個地址有BTC余額,那就恭喜你了,別人的錢就歸你了。所以你可知道保護錢包文件wallet.dat的重要性了吧?加密錢包後,向別人發送(付款)BTC時,會被要求輸入加密密碼,這樣安全性上多了一道保障。 查看原帖>>
㈡ 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;
}