话不多说,直接上示例代码
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后将会有一个 = 或两个 = 跟在后面,这样的话需要再解码之后看一下有几个 = ,再把解码过的数据进行删减。