我試圖用Crypto ++生成一個base64編碼字符串的SHA512。使用Crypto ++ Base64編碼器時避免換行
我的樣本輸入是:test123
的Base64:dGVzdDEyMw==
B64的SHA512(預期):9f012fff26c89f2650f7446a37e80ba6466d69ffc77bb9ffc8c09ab779b24a23bb6a2f3c28512668ebca8628303ab5a31067d930cd1af60c745a2c34e5b4b1d2
SHA512計算:
f78fa0aa79abd53b8181c5d21bdeb882bf45cd462a6e6e1b5043417de1800626
ed2a51b1a56626e9b9558da66a2f609d31db76bd88e80afbb7b03cda518b207d
B64(未預期的)的SHA512 :
byte *digest = new byte[CryptoPP::SHA512::DIGESTSIZE];
std::string encoded;
std::string test("test123");
CryptoPP::StringSource ss((byte*)test.data(), test.size(), true, new CryptoPP::Base64Encoder(new CryptoPP::StringSink(encoded))); // StringSource
// Calculate hash
CryptoPP::SHA512().CalculateDigest(digest, (byte*)encoded.data(), encoded.size());
如果我離開base64並直接計算SHA512,我得到正確的散列。因此計算不能完全錯誤。
但是,爲什麼它不適用於base64?