话不多说,直接上示例代码
std::string Base64Encode(const unsigned char* data, size_t size)
{
size_t base64_len = (size + 2) / 3 * 4;
if (base64_len == 0)
{
return "";
}
std::string ret;
ret.resize(base64_len);
EVP_EncodeBlock((unsigned char*)ret.data(), data, size);
return std::move(ret);
}
bool Base64Decode(const std::string& src, std::vector<unsigned char>& out)
{
size_t srcLen = src.size();
if (srcLen % 4 != 0)
{
return false;
}
size_t destLen = (srcLen / 4) * 3;
out.resize(destLen);
//todo: 判断返回值
int ret = EVP_DecodeBlock((unsigned char*)out.data(), (const unsigned char*)src.c_str(), (int)src.size());
if (ret == -1)
{
//base64 decode failed
return false;
}
int i = 0;
while (src.at(--srcLen) == '=')
{
ret--;
if (++i > 2)
{
// input maybe not base64 str;
return false;
}
}
out.resize(ret);
return true;
}
EVP_EncodeBlock 和 EVP_DecodeBlock openssl 内置的 base64 编解码的函数,这里稍微再做一下封装就可以了。
需要注意的是,被编码的数据大小不是3字节的整数倍时,base64后将会有一个 = 或两个 = 跟在后面,这样的话需要再解码之后看一下有几个 = ,再把解码过的数据进行删减。
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/279419.html