cryptopp base64编码/解码后的值不一样

时间:2014-04-15 21:55:00

标签: c++ base64 crypto++

我正在使用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)
    )
);

我的错误在哪里?

1 个答案:

答案 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 ++维基的例子,但我认为它看错了。