zoukankan      html  css  js  c++  java
  • 阿里云OSS-js分片上传

    使用 aliyun-oss-sdk-4.4.4.min.js

    方式一 客户端授权

    https://help.aliyun.com/document_detail/32069.html

    通过new OSS.Wapper()来创建client,OSS.Wrapper提供了异步的接口,类似于callback的方式,在.then()中处理返回的结果,在.catch()中处理错误。

    注意这里暴露了accessKeySecret,实际应用中在客户端不可采用这种方式。

    <body>
    <script src="http://gosspublic.alicdn.com/aliyun-oss-sdk-4.4.4.min.js"></script>
      <input type="file" id="file" />
      <script type="text/javascript">
        var client = new OSS.Wrapper({
          region: '<oss region>',
          accessKeyId: '<Your accessKeyId>',
          accessKeySecret: '<Your accessKeySecret>',
          bucket: '<Your bucket name>'
        });
        document.getElementById('file').addEventListener('change', function (e) {
          var file = e.target.files[0];
          var storeAs = 'upload-file';
          console.log(file.name + ' => ' + storeAs);
          client.multipartUpload(storeAs, file).then(function (result) {
            console.log(result);
          }).catch(function (err) {
            console.log(err);
          });
        });
      </script>
    </body>

    方式二 采用服务端授权

    https://github.com/rockuw/oss-in-browser

    <script>
    var
    appServer = 'http://localhost:3000';//STS授权服务端 var bucket = 'js-sdk-bucket-sts'; var region = 'oss-cn-hangzhou'; var urllib = OSS.urllib; var OSS = OSS.Wrapper; var STS = OSS.STS; var applyTokenDo = function (func) { var url = appServer; return urllib.request(url, { method: 'GET' }).then(function (result) { var creds = JSON.parse(result.data); var client = new OSS({ region: region, accessKeyId: creds.AccessKeyId, accessKeySecret: creds.AccessKeySecret, stsToken: creds.SecurityToken, bucket: bucket }); return func(client); }); }; var progress = function (p) { return function (done) { var bar = document.getElementById('progress-bar'); bar.style.width = Math.floor(p * 100) + '%'; bar.innerHTML = Math.floor(p * 100) + '%'; done(); } }; var uploadFile = function (client) { var file = document.getElementById('file').files[0]; var key = document.getElementById('object-key-file').value.trim() || 'object'; console.log(file.name + ' => ' + key); return client.multipartUpload(key, file, { progress: progress }).then(function (res) { console.log('upload success: %j', res); return listFiles(client); }); }; window.onload = function () { document.getElementById('file-button').onclick = function () { applyTokenDo(uploadFile); } };
    </script>

     NodeJS搭建的STS授权服务器

    https://github.com/rockuw/node-sts-app-server

  • 相关阅读:
    vue 引用本地图片
    antdVue
    Nest.js —— A progressive Node.js framework
    20184313《网络对抗技术》Exp8 Web综合
    20184313《网络对抗技术》Exp7 网络欺诈防范
    20184313《网络对抗技术》Exp6 MSF应用基础
    20184313《网络对抗技术》Exp5 信息搜集与漏洞扫描
    网页激知序列号之途径(网友提供技术参考)
    【转】Delphi中正则表达式支持中文的写法
    遇到的一个奇怪问题
  • 原文地址:https://www.cnblogs.com/imust2008/p/6869414.html
Copyright © 2011-2022 走看看