如何写入无用数据将 Base64 编码图片体积变大?

我有一段可以正常显示的base64编码图片
const base64Str = ;

我希望在base64Str中加入大量无用数据 使得

  1. 图片能够正常显示
  2. 图片宽高不发生改变
  3. 图片体积变大

请问应该写入什么数据才能,实现上述功能

阅读 3.8k
5 个回答

感谢各位回答,我从大家里面找到了一种实现思路
可以在base64编码字符串后面拼接大量base64编码后空格

下面是实现逻辑

    const extraDataSize = 1024 * 1024; //额外数据大小
    let rawBase64Str = ``
    window.onload = () => {
        const img = new Image();
        let decodedBase64Str = atob(rawBase64Str.split(",")[1]); //将base64进行解码
        decodedBase64Str = `${decodedBase64Str}${"x".repeat(extraDataSize)}` //塞入无效数据
        const base64Str = btoa(decodedBase64Str) //将数据转化为base64b编码
        img.src = "data:image/png;base64," + base64Str;
        document.body.append(img)
    }

让图片大小增大,这个需求是这样的,我们开发了一个mock服务器功能,会在客户端生成一张图片,用户可以自定义这个图片属性(宽高,背景色等)。对于前端开发而言,有时候需要测试大图片加载效果(比如做一些onload之类的加载效果),所以做了这个功能方便mock测试

真是奇葩的需求

base64的图片它也是图片文件呀,你只需要将这个文件末尾添加一堆无用的字节,图片解码的时候是根据规定的图片格式来的,自然会丢掉后面无用的数据。

用 js 操作的话需要先将base64字符串转为字节数组,然后就可以随意追加内容了 https://developer.mozilla.org...

<body>
</body>
<script>
  function b64ToUint6(nChr) {
    return nChr > 64 && nChr < 91 ?
      nChr - 65
      : nChr > 96 && nChr < 123 ?
        nChr - 71
        : nChr > 47 && nChr < 58 ?
          nChr + 4
          : nChr === 43 ?
            62
            : nChr === 47 ?
              63
              :
              0;
  }

  function base64DecToArr(sBase64, nBlocksSize) {
    var
      sB64Enc = sBase64.replace(/[^A-Za-z0-9\+\/]/g, ""), nInLen = sB64Enc.length,
      nOutLen = nBlocksSize ? Math.ceil((nInLen * 3 + 1 >> 2) / nBlocksSize) * nBlocksSize : nInLen * 3 + 1 >> 2, taBytes = new Uint8Array(nOutLen);
    for (var nMod3, nMod4, nUint24 = 0, nOutIdx = 0, nInIdx = 0; nInIdx < nInLen; nInIdx++) {
      nMod4 = nInIdx & 3;
      nUint24 |= b64ToUint6(sB64Enc.charCodeAt(nInIdx)) << 6 * (3 - nMod4);
      if (nMod4 === 3 || nInLen - nInIdx === 1) {
        for (nMod3 = 0; nMod3 < 3 && nOutIdx < nOutLen; nMod3++, nOutIdx++) {
          taBytes[nOutIdx] = nUint24 >>> (16 >>> nMod3 & 24) & 255;
        }
        nUint24 = 0;

      }
    }
    return taBytes;
  }

  function makeFat(image, extraByteSize = 10240) {
    const canvas = document.createElement('canvas');
    const ctx = canvas.getContext("2d");
    [canvas.width, canvas.height] = [image.width, image.height]
    ctx.drawImage(image, 0, 0);
    let b64Str = canvas.toDataURL("image/png");
    b64Str = b64Str.substring(b64Str.indexOf(";base64,") + 8);
    const buffer = base64DecToArr(b64Str);
    const newBuffer = new Uint8Array(buffer.length + extraByteSize);
    newBuffer.set(buffer);
    return newBuffer;
  }

  function download(imageBuffer) {
    const a = document.createElement("a");
    a.href = URL.createObjectURL(new Blob([imageBuffer], { type: "image/png" }));
    a.download = "image.png";
    document.body.appendChild(a);
    a.innerHTML = "Download"
  }

  const input = document.createElement("input");
  input.type = "file";
  input.accept = ".jpg";
  document.body.appendChild(input);
  input.onchange = async (e) => {
    if (e.target.files.length === 0) return;
    const image = new Image();
    image.src = URL.createObjectURL(e.target.files[0]);
    await new Promise(resolve => image.onload = resolve);
    document.body.appendChild(image);

    const buffer = makeFat(image);
    download(buffer);
  }
</script>

知道个别的办法,用windows窗口命令可以合并文件
copy /b 文件名1+文件名2+......文件名N 合并后的文件名
https://blog.csdn.net/GaoShi6...

利用canvas写入图片然后反向压缩后再生成base64

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题