美文网首页前端基础类学习
阿里OSS图片存储以及图片压缩

阿里OSS图片存储以及图片压缩

作者: 饥人谷_米弥轮 | 来源:发表于2018-10-27 15:16 被阅读113次
<!DOCTYPE html>
<html>

<head>
  <meta charset="UTF-8">
  <script type="text/javascript" src="http://libs.baidu.com/jquery/2.1.1/jquery.min.js"></script>
  <script type="text/javascript" src="aliyunOSS/aliyun-oss-sdk.js"></script>
  <title></title>
</head>

<body>
  <input type="file" id="file" multiple="multiple" />
  <script>
    //阿里云服务器对象
    var client = new OSS({
      region: 'oss-cn-shenzhen',
      accessKeyId: 'xxxxx', //阿里OSS信息
      accessKeySecret: 'xxxxxxx', //阿里OSS信息
      bucket: 'avic-paixiu-2019',
      secure: true //是否开启HTTPS
    });

    // 获取图片input选取的图片信息
    function fileChange(e) {
      let reader = new FileReader();  //异步读取计算机文件信息
      let file = e.target.files[0];
      let name = e.target.files[0].name
      let imgFile;
      reader.readAsDataURL(file);
      reader.onload = function (e) {
        imgFile = e.target.result;
        this.getImgToBase64(imgFile, function (data) {
          var myFile = dataURLtoFile(data, name);
          this.submit(myFile)
        }, 400, 400);
      };
    }

    // 使用canvas压缩图片并转换base64
    function getImgToBase64(url, callback, width, height, ratio) {
      //将图片转换为Base64并压缩
      var canvas = document.createElement("canvas"),
        ctx = canvas.getContext("2d"),
        img = new Image();
      img.crossOrigin = "Anonymous";
      img.onload = function () {
        canvas.height = width;  //转换图片像素大小
        canvas.width = height;
        ctx.drawImage(img, 0, 0, width, height);
        var dataURL = canvas.toDataURL("image/png", ratio);  //通过canvas获取图片的base64的URL
        callback(dataURL);
        canvas = null;
      };
      img.src = url;
    }

    // base64转换文件
    function dataURLtoFile(dataurl, filename) {
      //将base64转换为文件
      var arr = dataurl.split(","),
        mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]),  //base64解码JS API(还有一个JS API做base64转码:btoa())
        n = bstr.length,
        u8arr = new Uint8Array(n);
      while (n--) {
        u8arr[n] = bstr.charCodeAt(n);
      }
      return new File([u8arr], filename, {  //将base64转成文件
        type: mime
      });
    }

    // 提交阿里OSS
    function submit(imgfile) {
      //获取uuid
      function guid() {
        return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
          var r = Math.random() * 16 | 0,
            v = c == 'x' ? r : (r & 0x3 | 0x8);
          return v.toString(16);
        });
      }

      //日期格式化
      Date.prototype.Format = function (fmt) { //author: meizz 
        var o = {
          "M+": this.getMonth() + 1, //月份 
          "d+": this.getDate(), //日 
          "h+": this.getHours(), //小时 
          "m+": this.getMinutes(), //分 
          "s+": this.getSeconds(), //秒 
          "q+": Math.floor((this.getMonth() + 3) / 3), //季度 
          "S": this.getMilliseconds() //毫秒 
        };
        if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
        for (var k in o)
          if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : ((
            "00" + o[k]).substr(("" + o[k]).length)));
        return fmt;
      }

      var basePath = new Date().Format('yyyy/MM/dd/');
      //paixiu-img/2018/10/24/uuid
      client.multipartUpload('图片文件夹名称' + basePath + guid(), imgFile).then(function (result) {
        console.log(result);
      }).catch(function (err) {
        console.log(err);
      });
    }

    $('#file').on('change', fileChange);
  </script>
</body>

</html>

javascript 使用btoa和atob来进行Base64转码和解码

javascript原生的api本来就支持,Base64,但是由于之前的javascript局限性,导致Base64基本中看不中用。当前html5标准正式化之际,Base64将有较大的转型空间,对于Html5 Api中出现的如FileReader Api, 拖拽上传,甚至是Canvas,Video截图都可以实现。

好了,前言说了一大堆,开发者需要重视:

一.我们来看看,在javascript中如何使用Base64转码

var str = 'javascript';

window.btoa(str)
//转码结果 "amF2YXNjcmlwdA=="

window.atob("amF2YXNjcmlwdA==")
//解码结果 "javascript"

二.对于转码来说,Base64转码的对象只能是字符串,因此来说,对于其他数据还有这一定的局限性,在此特别需要注意的是对Unicode转码。

var str = "China,中国"
window.btoa(str)

Uncaught DOMException: Failed to execute 'btoa' on 'Window': The string to be encoded contains characters outside of the Latin1 range.

很明显,这种方式是不行的,那么如何让他支持汉字呢,这就要使用window.encodeURIComponent和window.decodeURIComponent

var str = "China,中国";

window.btoa(window.encodeURIComponent(str))
//"Q2hpbmElRUYlQkMlOEMlRTQlQjglQUQlRTUlOUIlQkQ="

window.decodeURIComponent(window.atob('Q2hpbmElRUYlQkMlOEMlRTQlQjglQUQlRTUlOUIlQkQ='))
//"China,中国"

相关文章

网友评论

    本文标题:阿里OSS图片存储以及图片压缩

    本文链接:https://www.haomeiwen.com/subject/tcsdtqtx.html