void base64_encode_s(const unsigned char *str, long inlen, std::string& outstr, long* lpBufLen)
{
long len;
long str_len;
//unsigned char *res;
//std::shared_ptr<std::string> res;
int i,j;
//定义base64编码表
const unsigned char *base64_table = (const unsigned char *)("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"); //计算经过base64编码后的字符串长度
str_len= inlen;
if(str_len % == )
len=str_len/*;
else
len=(str_len/+)*; if (NULL != lpBufLen) {
*lpBufLen = len;
} //std::shared_ptr<std::string> res(new std::string(sizeof(unsigned char)*len+1)); //(unsigned char *)malloc(sizeof(unsigned char)*len+1);
outstr.resize(sizeof(unsigned char)*len+);
outstr[len] = '\0'; //以3个8位字符为一组进行编码
for(i=,j=;i<len-;j+=,i+=)
{
outstr[i] = base64_table[str[j]>>]; //取出第一个字符的前6位并找出对应的结果字符
outstr[i+] = base64_table[(str[j]&0x3)<< | (str[j+]>>)]; //将第一个字符的后位与第二个字符的前4位进行组合并找到对应的结果字符
outstr[i+] = base64_table[(str[j+]&0xf)<< | (str[j+]>>)]; //将第二个字符的后4位与第三个字符的前2位组合并找出对应的结果字符
outstr[i+] = base64_table[str[j+]&0x3f]; //取出第三个字符的后6位并找出结果字符
} switch(str_len % )
{
case :
outstr[i-]='=';
outstr[i-]='=';
break;
case :
outstr[i-]='=';
break;
} return;
} void base64_decode_s(const unsigned char *code, std::string& outstr, long* lpBufLen)
{
//根据base64表,以字符找到对应的十进制数据
int table[]={,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,
,,,,,,,,
,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,
,,,,,,,,,,,
,,,,,,,,,
,,,,,,,,,
,,,,,,
};
long len;
long str_len;
//unsigned char *res = NULL;
int i,j; //计算解码后的字符串长度
len = strlen((const char*)code);
//判断编码后的字符串后是否有=
if(strstr((const char*)code,"=="))
str_len=len/*-;
else if(strstr((const char*)code,"="))
str_len=len/*-;
else
str_len=len/*; if (NULL != lpBufLen) {
*lpBufLen = str_len;
} //res = (unsigned char*)malloc(sizeof(unsigned char)*str_len+1);
outstr.resize(sizeof(unsigned char)*len+);
//memset(outstr.,0, str_len+1);
//res[str_len]='\0'; //以4个字符为一位进行解码
for(i=,j=;i < len-;j+=,i+=)
{
outstr[j]=((unsigned char)table[code[i]])<< | (((unsigned char)table[code[i+]])>>); //取出第一个字符对应base64表的十进制数的前6位与第二个字符对应base64表的十进制数的后2位进行组合
outstr[j+]=(((unsigned char)table[code[i+]])<<) | (((unsigned char)table[code[i+]])>>); //取出第二个字符对应base64表的十进制数的后4位与第三个字符对应bas464表的十进制数的后4位进行组合
outstr[j+]=(((unsigned char)table[code[i+]])<<) | ((unsigned char)table[code[i+]]); //取出第三个字符对应base64表的十进制数的后2位与第4个字符进行组合
} return;
}

base64编解码的两个函数(安全版本)的更多相关文章

  1. base64编解码的两个函数

    base64编解码的两个函数,声明,参考网络上的代码实现. unsigned char *base64_encode(unsigned char *str, long* lpBufLen) { lon ...

  2. Delphi Base64 编解码函数

    Delphi 自带 Base64 编解码的单元, EncdDecd这个单元提供两套四个公开函数: 对流的编解码:procedure EncodeStream(Input, Output: TStrea ...

  3. Delphi 自带的 Base64 编解码函数

    今天帮别人解决一个关于 Base64 编解码的问题,竟然发现 Delphi 自带了 Base64 编解码的单元,叫 EncdDecd,这名字很拗口而且不直观,估计这是一直很少人关注和知道的原因. 这个 ...

  4. ios Base64编解码工具类及使用

    为了避免明码传递http内容,可以用base64编码后传输,收到方再解码,也方便了2进制数据的字符串式传输. 对于ios来说,google给提供了一个很好的工具类,方便进行base64编解码,当然也可 ...

  5. Delphi 自带了 Base64 编解码的单元

    Delphi 自带了 Base64 编解码的单元,叫 EncdDecd,这名字很拗口而且不直观,估计这是一直很少人关注和知道的原因.  这个单元提供两套四个公开函数:  对流的编解码: procedu ...

  6. EasyDarwin开源流媒体云平台中boost Base64编解码后与源长度不匹配的bug

    本文转自EasyDarwin团队Alex的博客:http://blog.csdn.net/cai6811376 EasyDarwin云平台中部分协议使用了Base64编码昨晚报文通信的载体.比如在对摄 ...

  7. 【VBA研究】如何用Base64 编解码方法实现简单的加解密

    Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码,将数据变成字符串实现文本传输.由于编码简单,所以很容易实现,代码也是现成的.利用这个编码规则可以实现简单的加解密.编解码方 ...

  8. C#字符串Base64编解码

    C#字符串Base64编解码 首先讲一下什么是Base64编码所谓Base64就是一种基于64个可打印字符来表示二进制数据的方法.Base64编码是从二进制到字符的过程,常用于在网络上传输不可见字符( ...

  9. Java实现BASE64编解码

    Java实现BASE64编解码 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs BASE64和其它类似的编码算法通经常使用于转换二进制数据为文本数据,其目 ...

随机推荐

  1. Kibana 基本操作

    es中的索引对应mysql的数据库.类型对应mysql的表.文档对应mysql的记录.映射对应mysql的索引索引:index类型:type映射:mappings 1.创建索引在kibana的Dev ...

  2. lilo.conf - lilo 配置文件

    描述 默认情况下,本文件 ( /etc/lilo.conf ) 由引导管理程序 lilo 读取 (参考 lilo(8)). 它看起来可能象这样: boot = /dev/hda delay = 40 ...

  3. STM32 时钟系统

    1.在 STM32F4 中,有 5 个最重要的时钟源,为 HSI.HSE.LSI.LSE.PLL.其中 PLL 实际是分为两个时钟源,分别为主 PLL 和专用 PLL. 2.   ①.LSI 是低速内 ...

  4. 028-实现阿里云ESC多FLAT网络

    实现类似于阿里云ECS的网络结构,其效果为云主机拥有两块和两个不同的网络,一个网络是用于用于和外网连接,一个用于内网通信,但宿主机上至少有两个网卡,整体配置如下:1.在wmare里给宿主机添加一块网卡 ...

  5. bzoj5017 [Snoi2017]炸弹 (线段树优化建图+)tarjan 缩点+拓扑排序

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5017 题解 这个题目方法挺多的. 线段树优化建图 线段树优化建图的做法应该挺显然的,一个炸弹能 ...

  6. Spring Boot日志处理

    2.4 日志处理 2.4.1 记录日志内容 请求url 访问者ip 调用方法classMethod 参数args 返回内容 2.4.2 新建包aspect,新建日志切面处理类 package com. ...

  7. apache-2.4.x 编译安装方法

    apache-2.4.x 编译安装方法 作者:朱 茂海 /分类:Apache 字号:L M S apache-.2与新出的apache-.4安装不同的地方在于,.4版的已经不自带apr库,所以在安装a ...

  8. Python---Tkinter---贪吃蛇

    # 项目分析: - 构成: - 蛇  Snake - 食物 Food - 世界 World - 蛇和食物属于整个世界 class World: self.snake self.food ------- ...

  9. 【leetcode】1146. Snapshot Array

    题目如下: Implement a SnapshotArray that supports the following interface: SnapshotArray(int length) ini ...

  10. postman-鉴权

    概念 Cookie和鉴权的区别,cookie一般指缓存在本地的数据:鉴权一般指验证用户是否拥有访问系统的权利 鉴权分类 Basic auth:基础鉴权,数据没有加密可明文显示,一般在测试环境使用,不在 ...