base64编解码的两个函数(安全版本)
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编解码的两个函数(安全版本)的更多相关文章
- base64编解码的两个函数
base64编解码的两个函数,声明,参考网络上的代码实现. unsigned char *base64_encode(unsigned char *str, long* lpBufLen) { lon ...
- Delphi Base64 编解码函数
Delphi 自带 Base64 编解码的单元, EncdDecd这个单元提供两套四个公开函数: 对流的编解码:procedure EncodeStream(Input, Output: TStrea ...
- Delphi 自带的 Base64 编解码函数
今天帮别人解决一个关于 Base64 编解码的问题,竟然发现 Delphi 自带了 Base64 编解码的单元,叫 EncdDecd,这名字很拗口而且不直观,估计这是一直很少人关注和知道的原因. 这个 ...
- ios Base64编解码工具类及使用
为了避免明码传递http内容,可以用base64编码后传输,收到方再解码,也方便了2进制数据的字符串式传输. 对于ios来说,google给提供了一个很好的工具类,方便进行base64编解码,当然也可 ...
- Delphi 自带了 Base64 编解码的单元
Delphi 自带了 Base64 编解码的单元,叫 EncdDecd,这名字很拗口而且不直观,估计这是一直很少人关注和知道的原因. 这个单元提供两套四个公开函数: 对流的编解码: procedu ...
- EasyDarwin开源流媒体云平台中boost Base64编解码后与源长度不匹配的bug
本文转自EasyDarwin团队Alex的博客:http://blog.csdn.net/cai6811376 EasyDarwin云平台中部分协议使用了Base64编码昨晚报文通信的载体.比如在对摄 ...
- 【VBA研究】如何用Base64 编解码方法实现简单的加解密
Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码,将数据变成字符串实现文本传输.由于编码简单,所以很容易实现,代码也是现成的.利用这个编码规则可以实现简单的加解密.编解码方 ...
- C#字符串Base64编解码
C#字符串Base64编解码 首先讲一下什么是Base64编码所谓Base64就是一种基于64个可打印字符来表示二进制数据的方法.Base64编码是从二进制到字符的过程,常用于在网络上传输不可见字符( ...
- Java实现BASE64编解码
Java实现BASE64编解码 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs BASE64和其它类似的编码算法通经常使用于转换二进制数据为文本数据,其目 ...
随机推荐
- 移动端布局的思考和rem的设置
如下方法如有不正确的地方,欢迎指正 前提: 设置稿750px 目标:40px = 1rem js设置方法:(小于等于750屏幕等比缩放) ;(function (doc, win, undefined ...
- ECMAScript(ES) 6 之 let 与 const
ES6 新增加了两个重要的 JavaScript 关键字 :let 和 const 先说一下 const :它用于声明一个只读的常量,一旦声明,常量的值就不能改变. const servicePat ...
- [转载]Quartus ii 一些Warning/Eeror分析与解决
我会在此基础上继续添加 原文地址:ii 一些Warning/Eeror分析与解决">Quartus ii 一些Warning/Eeror分析与解决作者:yanppf 注:http:// ...
- 使ApacheBench支持multi-url
目录 1.下载Apache httpd相关源码包以及针对ab工具的patch包 2.编译安装apr 3.编译安装apr-util 4.替换httpd源码里面的ab.c文件 5.编译安装httpd 6. ...
- 详解InitializingBean、initMethod和@PostConstruct
转载:https://blog.csdn.net/nrsc272420199/article/details/95033223 1. InitializingBean.initMethod和@Post ...
- SpringBoot之集成数据库
一.集成 MySQL 数据库 1.1 配置 MySQL 添加依赖 <dependencies> <!--Spring 数据库相关依赖--> <dependency> ...
- Spring Boot 使用Mybatis注解开发增删改查
使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...
- Python---Tkinter---贪吃蛇(稳定的外部环境,稳定的内心)
# 项目分析: - 构成: - 蛇 Snake - 食物 Food - 世界 World - 蛇和食物属于整个世界 class World: self.snake self.food - 上面代码不太 ...
- 【leetcode】1106. Parsing A Boolean Expression
题目如下: Return the result of evaluating a given boolean expression, represented as a string. An expres ...
- 51nod1790 输出二进制数
题目描述 题解 过于真实 LJ卡常题 一个显然的dp: 设f[i][j]表示做完前i个,最后一段为j+1~i的方案(最小值同理) 那么f[i][j]=min(f[i-j-1][k]),其中k~j-1要 ...