关于前端使用JavaScript获取base64图片大小的方法
Posted The Beatles
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于前端使用JavaScript获取base64图片大小的方法相关的知识,希望对你有一定的参考价值。
base64原理
Base64编码要求把3个8位字节(38=24)转化为4个6位的字节(46=24),之后在6位的前面补两个0,形成8位一个字节的形式。 如果剩下的字符不足3个字节,则用0填充,输出字符使用’=’,因此编码后输出的文本末尾可能会出现1或2个’=’
如何获取base64图片大小
通过base64编码原理我们知道,base64的图片字符流中的每8个字符就有两个是用0补充,而且字符流的末尾还可能存在‘=’号,我们可以通过这个原理计算图片的文件流大小。
getImgByteSize(data) {
if (data.graphicContents) { // 获取base64图片byte大小
const equalIndex = data.graphicContents.indexOf('='); // 获取=号下标
if (equalIndex > 0) {
const str = data.graphicContents.substring(0, equalIndex); // 去除=号
const strLength = str.length;
const fileLength = strLength - (strLength / 8) * 2; // 真实的图片byte大小
data.size = Math.floor(fileLength); // 向下取整
} else {
const strLength = data.graphicContents.length;
const fileLength = strLength - (strLength / 8) * 2;
data.size = Math.floor(fileLength); // 向下取整
}
} else {
data.size = null;
}
}
data.graphicContents是后端获取的base64图片的字符串。
以上是关于关于前端使用JavaScript获取base64图片大小的方法的主要内容,如果未能解决你的问题,请参考以下文章
zbb20180921 java,js,javascript 前端加密后端解密Base64通用加密处理
javascript 转换图像是一个base64 con JavaScript