Base64编码为什么会使数据量变大?
2016-06-29 00:00
477 查看
摘要: http://blog.csdn.net/sallay/article/details/3550740
图片上传,以二进制字节流byte[]上传,通过base64_encode之后字符串时数据量明显变大,为何呢?这里就得先探究一下什么是Base64编码。
Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个"="。( 注BASE64字符表:ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/)
从以上编码规则可以得知,通过Base64编码,原来的3个字节编码后将成为4个字节,即字节增加了33.3%,数据量相应变大。所以20M的数据通过Base64编码后大小大概为20M*133.3%=26.67M。
图片上传,以二进制字节流byte[]上传,通过base64_encode之后字符串时数据量明显变大,为何呢?这里就得先探究一下什么是Base64编码。
Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个"="。( 注BASE64字符表:ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/)
从以上编码规则可以得知,通过Base64编码,原来的3个字节编码后将成为4个字节,即字节增加了33.3%,数据量相应变大。所以20M的数据通过Base64编码后大小大概为20M*133.3%=26.67M。
相关文章推荐
- utf8 和 UTF-8 在使用中的区别
- 使用net.sf.json.JSONObject转jsonObject的问题
- 为什么 Google 将数十亿行代码储存在单一的源码库
- Num62 理财产品的查看和修改
- tomcat启动慢的原因分析
- 日志输出 logback.xml 放置的位置以及找不到logback.xml文件的问题
- hadoop: hdfs API示例
- 网页里唤起客户端方式
- Java的正则表达式使用及案例
- HttpClient使用详解
- java求二叉树的深度
- 翻转句子中单词的序列
- 剑指offer:删除链表中重复的结点
- 剑指offer:java判断二叉树是否对称
- 剑指offer:序列化二叉树
- 机器学习及其分类
- Xamarin如何生成Android项目的APK
- 华为手机 开启LOGCAT
- 0.osframe框架启动入门说明
- ceph: how to fix if monitor IP changes