canvas等base64格式上傳到服務端直傳到oss


一般來說,我們用畫布,html2canvas這些獲取的都為base64格式的

html2canvas(document.body, {
  onrendered: function (canvas) {
  console.log('。。。。。。', canvas.toDataURL("image/png"));
  },
});
但是上傳到oss是不可以直接上傳base64的,需要把base64轉換成blob,然后把blob轉換成file文件的形式
我們在之前拿到了base64文件,現在把他轉換成blob形式的:
var _fileBlob = dataURLtoBlob(base);
function dataURLtoBlob(dataurl) {
  var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
  bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
  while (n--) {
    u8arr[n] = bstr.charCodeAt(n);
  }
  return new Blob([u8arr], { type: mime });
}
最后把blob轉換成file文件形式:
let fileOfBlob = new File([_fileBlob], new Date() + '.jpg');
//這里默認上傳為jpg格式的
即可把這個ileOfBlob加到var request = new FormData();這里來:
request.append('file', fileOfBlob);
 
值得注意的是,好像oss上傳有順序規則
1.request.append('name', 'Picture_G_Balloon.jpg');
2.request.append('key', random_name);
3.request.append("policy", data.policy);//policy規定了請求的表單域的合法性
4.request.append("OSSAccessKeyId", data.ossaccessKeyId);//Bucket 擁有者的Access Key Id。
5.request.append("success_action_status", '200');// 讓服務端返回200,不然,默認會返回204
6.request.append("Signature", data.signature);//根據Access Key Secret和policy計算的簽名信息,OSS驗證該簽名信息從而驗證該Post請求的合法性
7request.append('file', fileOfBlob);
貌似要這樣的順序,不然會報錯,很奇怪,不知道是不是后台上傳的設置。。。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM