溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信小程序環(huán)境下如何將文件上傳到OSS

發(fā)布時(shí)間:2021-07-20 11:19:40 來源:億速云 閱讀:173 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了微信小程序環(huán)境下如何將文件上傳到OSS,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

步驟 1: 配置 Bucket 跨域

客戶端進(jìn)行表單直傳到 OSS 時(shí),會(huì)從瀏覽器向 OSS 發(fā)送帶有 Origin 的請(qǐng)求消息。OSS 對(duì)帶有 Origin 頭的請(qǐng)求消息會(huì)進(jìn)行跨域規(guī)則(CORS)的驗(yàn)證。因此需要為 Bucket 設(shè)置跨域規(guī)則以支持 Post 方法。

微信小程序環(huán)境下如何將文件上傳到OSS

步驟 2:配置外網(wǎng)域名到小程序的上傳域名白名單中

通過 OSS 控制臺(tái)查看外網(wǎng)域名。

微信小程序環(huán)境下如何將文件上傳到OSS

登錄微信小程序平臺(tái),配置小程序的上傳域名白名單。

微信小程序環(huán)境下如何將文件上傳到OSS

步驟 3:使用 Web 端直傳實(shí)踐方案 Demo 進(jìn)行上傳測(cè)試

下載應(yīng)用服務(wù)器代碼

修改 Demo 中 upload.js 的密鑰和地址。

微信小程序環(huán)境下如何將文件上傳到OSS

進(jìn)行上傳測(cè)試。

微信小程序環(huán)境下如何將文件上傳到OSS

微信小程序環(huán)境下如何將文件上傳到OSS

微信小程序環(huán)境下如何將文件上傳到OSS

獲取上傳需要的簽名(signature)和加密策略(policy)

使用微信小程序上傳圖片

使用 chooseImage API 進(jìn)行圖片選擇,然后調(diào)用 uploadFile 進(jìn)行文件上傳

微信小程序環(huán)境下如何將文件上傳到OSS

幫助文檔

upload.js

accessid= '';
accesskey= '';
host = '';

g_dirname = ''
g_object_name = ''
g_object_name_type = ''
now = timestamp = Date.parse(new Date()) / 1000; 

var policyText = {
  "expiration": "2020-01-01T12:00:00.000Z", //設(shè)置該P(yáng)olicy的失效時(shí)間,超過這個(gè)失效時(shí)間之后,就沒有辦法通過這個(gè)policy上傳文件了
  "conditions": [
  ["content-length-range", 0, 1048576000] // 設(shè)置上傳文件的大小限制
  ]
};

var policyBase64 = Base64.encode(JSON.stringify(policyText))
message = policyBase64
var bytes = Crypto.HMAC(Crypto.SHA1, message, accesskey, { asBytes: true }) ;
var signature = Crypto.util.bytesToBase64(bytes);

function check_object_radio() {
  var tt = document.getElementsByName('myradio');
  for (var i = 0; i < tt.length ; i++ )
  {
    if(tt[i].checked)
    {
      g_object_name_type = tt[i].value;
      break;
    }
  }
}

function get_dirname()
{
  dir = document.getElementById("dirname").value;
  if (dir != '' && dir.indexOf('/') != dir.length - 1)
  {
    dir = dir + '/'
  }
  //alert(dir)
  g_dirname = dir
}

function random_string(len) {
  len = len || 32;
  var chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';  
  var maxPos = chars.length;
  var pwd = '';
  for (i = 0; i < len; i++) {
    pwd += chars.charAt(Math.floor(Math.random() * maxPos));
  }
  return pwd;
}

function get_suffix(filename) {
  pos = filename.lastIndexOf('.')
  suffix = ''
  if (pos != -1) {
    suffix = filename.substring(pos)
  }
  return suffix;
}

function calculate_object_name(filename)
{
  if (g_object_name_type == 'local_name')
  {
    g_object_name += "${filename}"
  }
  else if (g_object_name_type == 'random_name')
  {
    suffix = get_suffix(filename)
    g_object_name = g_dirname + random_string(10) + suffix
  }
  return ''
}

function get_uploaded_object_name(filename)
{
  if (g_object_name_type == 'local_name')
  {
    tmp_name = g_object_name
    tmp_name = tmp_name.replace("${filename}", filename);
    return tmp_name
  }
  else if(g_object_name_type == 'random_name')
  {
    return g_object_name
  }
}

function set_upload_param(up, filename, ret)
{
  g_object_name = g_dirname;
  if (filename != '') {
    suffix = get_suffix(filename)
    calculate_object_name(filename)
  }
  new_multipart_params = {
    'key' : g_object_name,
    'policy': policyBase64,
    'OSSAccessKeyId': accessid, 
    'success_action_status' : '200', //讓服務(wù)端返回200,不然,默認(rèn)會(huì)返回204
    'signature': signature,
  };

  up.setOption({
    'url': host,
    'multipart_params': new_multipart_params
  });

  up.start();
}

var uploader = new plupload.Uploader({
  runtimes : 'html5,flash,silverlight,html4',
  browse_button : 'selectfiles', 
  //multi_selection: false,
  container: document.getElementById('container'),
  flash_swf_url : 'lib/plupload-2.1.2/js/Moxie.swf',
  silverlight_xap_url : 'lib/plupload-2.1.2/js/Moxie.xap',
  url : 'http://oss.aliyuncs.com',

  init: {
    PostInit: function() {
      document.getElementById('ossfile').innerHTML = '';
      document.getElementById('postfiles').onclick = function() {
      set_upload_param(uploader, '', false);
      return false;
      };
    },

    FilesAdded: function(up, files) {
      plupload.each(files, function(file) {
        document.getElementById('ossfile').innerHTML += '<div id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ')<b></b>'
        +'<div class="progress"><div class="progress-bar" ></div></div>'
        +'</div>';
      });
    },

    BeforeUpload: function(up, file) {
      check_object_radio();
      get_dirname();
      set_upload_param(up, file.name, true);
    },

    UploadProgress: function(up, file) {
      var d = document.getElementById(file.id);
      d.getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";
      var prog = d.getElementsByTagName('div')[0];
      var progBar = prog.getElementsByTagName('div')[0]
      progBar.style.width= 2*file.percent+'px';
      progBar.setAttribute('aria-valuenow', file.percent);
    },

    FileUploaded: function(up, file, info) {
      if (info.status == 200)
      {
        document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = 'upload to oss success, object name:' + get_uploaded_object_name(file.name);
      }
      else
      {
        document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = info.response;
      } 
    },

    Error: function(up, err) {
      document.getElementById('console').appendChild(document.createTextNode("\nError xml:" + err.response));
    }
  }
});

uploader.init();

index.html

<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
  <title>OSS web直傳</title>
  <link rel="stylesheet" type="text/css" href="style.css"/>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
</head>
<body>

<h3>OSS web直傳---直接在JS簽名</h3>
<ol>
<li>基于plupload封裝 </li>
<li>支持html5,flash,silverlight,html4 等協(xié)議上傳</li>
<li>可以運(yùn)行在PC瀏覽器,手機(jī)瀏覽器,微信</li>
<li>可以選擇多文件上傳</li>
<li>顯示上傳進(jìn)度條</li>
<li>可以控制上傳文件的大小</li>
<li>最關(guān)鍵的是,讓你10分鐘之內(nèi)就能移植到你的系統(tǒng),實(shí)現(xiàn)以上牛逼的功能!</li>
<li>注意一點(diǎn),bucket必須設(shè)置了Cors(Post打勾),不然沒有辦法上傳</li>
<li>注意一點(diǎn),把upload.js 里面的host/accessid/accesskey改成您上傳所需要的信息即可</li>
<li>此方法是直接在前端簽名,有accessid/accesskey泄漏的風(fēng)險(xiǎn), 線上生產(chǎn)請(qǐng)使用后端簽名例子<a href="https://help.aliyun.com/document_detail/oss/practice/pc_web_upload/js_php_upload.html">點(diǎn)擊查看詳細(xì)文檔</a></li>
</ol>
<br>
<form name=theform>
<input type="radio" name="myradio" value="local_name" checked=true/> 上傳文件名字保持本地文件名字
<input type="radio" name="myradio" value="random_name" /> 上傳文件名字是隨機(jī)文件名
<br/>
上傳到指定目錄:<input type="text" id='dirname' placeholder="如果不填,默認(rèn)是上傳到根目錄" size=50>
</form>

<h5>您所選擇的文件列表:</h5>
<div id="ossfile">你的瀏覽器不支持flash,Silverlight或者HTML5!</div>

<br/>

<div id="container">
  <a id="selectfiles" href="javascript:void(0);" class='btn'>選擇文件</a>
  <a id="postfiles" href="javascript:void(0);" class='btn'>開始上傳</a>
</div>

<pre id="console"></pre>

<p>&nbsp;</p>

</body>
<script type="text/javascript" src="lib/crypto1/crypto/crypto.js"></script>
<script type="text/javascript" src="lib/crypto1/hmac/hmac.js"></script>
<script type="text/javascript" src="lib/crypto1/sha1/sha1.js"></script>
<script type="text/javascript" src="lib/base64.js"></script>
<script type="text/javascript" src="lib/plupload-2.1.2/js/plupload.full.min.js"></script>
<script type="text/javascript" src="upload.js"></script>
</html>

實(shí)現(xiàn)點(diǎn)擊按鈕選擇圖片后顯示圖片并且可以預(yù)覽該圖片

微信小程序環(huán)境下如何將文件上傳到OSS

微信小程序環(huán)境下如何將文件上傳到OSS

微信小程序環(huán)境下如何將文件上傳到OSS

微信小程序環(huán)境下如何將文件上傳到OSS

跳轉(zhuǎn)的按鈕在子組件

this.$navigate({url:"content"})

this.$parent.$navigate({url:"content"})

wepy.navigateTo({
url: '/pages/content'
})

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“微信小程序環(huán)境下如何將文件上傳到OSS”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI