图片转base64方法总结

3 篇文章 0 订阅

将图片转为base64格式是一种比较常见的需求,今天就总结一下在浏览器中和服务器上比较常用的几种方法。

通过canvas将图片转base64

<!DOCTYPE html>
<html lang='zh'>
<head>
  <meta charset='UTF-8' />
  <meta name='viewport' content='width=device-width, initial-scale=1.0' />
  <meta http-equiv='X-UA-Compatible' content='ie=edge' />
  <title>通过canvas将图片转base64</title>
</head>
<body>
  <img src=""/>
  <script type='text/javascript'>
    /**
     * @desc 图片转base64
     * @args {String} imgUrl 图片地址
     * @args {Number} quality 图片质量
     */
    function getBase64Image(imgUrl, quality = 0.5) {
      var img = new Image();
      img.src = imgUrl
      return new Promise(resolve => {
        img.onload = function() {
          var canvas = document.createElement("canvas");
          canvas.width = img.width;
          canvas.height = img.height;
          var ctx = canvas.getContext("2d");
          ctx.drawImage(img, 0, 0, img.width, img.height);
          dataURL = canvas.toDataURL('image/jpeg', quality);
          resolve(dataURL)
        }
      })
    }
    // 仅支持本地图片
    getBase64Image("./pic.png", 0.8).then(function(base64) {
      console.log(base64)
      document.querySelector('img').src = base64
    })
  </script>
</body>
</html>

通过html2canvas将页面转化为图片(推荐)

<!DOCTYPE html>
<html lang='zh'>
<head>
  <meta charset='UTF-8' />
  <meta name='viewport' content='width=device-width, initial-scale=1.0' />
  <meta http-equiv='X-UA-Compatible' content='ie=edge' />
  <title>通过html2canvas将页面转化为图片</title>
</head>
<body> 
  <!--本地线上都行,线上需要设置CROS-->
  <img src='https://wx.qlogo.cn/mmopen/vi_32/UQoHn9hFNXbeJD1EdLAdBhWfFcIBKViajWOicl2uticOVNs1FKdO5d80QLVjPCnL3LY53gs0EbmIFl5zDgLI7oGTw/132'/>
  <script src="https://daoket.gitee.io/ai/js/html2canvas.min.js"></script>
  <script type='text/javascript'>
    html2canvas(document.querySelector('img'), {useCORS: true}).then(function(canvas) {
      var base64 = canvas.toDataURL("image/jpeg", 0.1);
      document.body.appendChild(canvas);
      console.log(base64)

//    downloadImg(base64, "meme.png")
    });

    // 下载图片
    function downloadImg(base64, imgName) {
      var a = document.createElement("a");
      a.href = base64;
      a.download = imgName;
      a.click();
    }
  </script>
</body>
</html>

通过node的fs.readFile转换

const fs = require('fs');

fs.readFile('./a.png', 'base64', (err, data) => {
  // 图片需要在data前加上 'data:image/png;base64,'
  console.log(data)
});

通过node的fs.createReadStream转换

var fs = require('fs');
var readStream = fs.createReadStream('./pic.png');

readStream.on('data', function (chunk) {
  console.log(chunk.toString('base64')) 
});

通过Buffer转化

let base64 = Buffer.from('把我转化为base64').toString('base64')
console.log(base64)
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值