我正在使用cryptopp并且无法使用Base64编码/解码。
在下面的代码中,假设sig
值应该等于tsig
,但它们在最后一个字符(sig
大于tsig
一个符号)上是不同的。我已尝试更改insertLineBreaks
中的Base64Encoder
参数,但结果相同。
...
RSASSA_PKCS1v15_SHA_Signer privkey(privateKey);
SecByteBlock sbbSignature(privkey.SignatureLength());
privkey.SignMessage(rng, (byte const*) strContents.data(),
strContents.size(),sbbSignature);
Base64Encoder b(new StringSink(signedData));
b.Put(sbbSignature.begin(), sbbSignature.size());
string sig;
StringSink sinksig(sig);
sinksig.Put(sbbSignature.begin(), sbbSignature.size());
string tsig;
StringSource ss(signedData, true,
new Base64Decoder(
new StringSink(tsig)
)
);
我的错误在哪里?
答案 0 :(得分:1)
b.Put(sbbSignature.begin(), sbbSignature.size());
尝试:
b.Put(sbbSignature.begin(), sbbSignature.size());
b.MessgeEnd();
这看起来不太合适:
SecByteBlock sbbSignature(privkey.SignatureLength());
privkey.SignMessage(rng, (byte const*) strContents.data(),
strContents.size(),sbbSignature);
尝试:
size_t maxLength = privkey.MaxSignatureLength();
SecByteBlock sbbSignature(maxLength);
size_t signatureLength = privkey.SignMessage(rng,
(byte const*) strContents.data(), strContents.size(),
sbbSignature);
if(maxLength != signatureLength)
sbbSignature.resize(signatureLength);
RSA Signature Scheme with Appendix上有一个关于Crypto ++维基的例子,但我认为它看错了。