国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

data:image data url 文件轉為Blob上傳后端的方法

2024-08-26 00:21:34
字體:
來源:轉載
供稿:網友

一些場景,比如canvas獲取的圖片,或者微信開發sdk返回的圖片格式是data:img格式的,我們需要上傳到服務器上,那就需要進行轉化。

將dataURL轉成Blob

// base64 轉 blobdataURItoBlob(dataURI) {  // convert base64/URLEncoded data component to raw binary data held in a string  let byteString;  if (dataURI.split(',')[0].indexOf('base64') >= 0) {    byteString = atob(dataURI.split(',')[1]);  } else byteString = unescape(dataURI.split(',')[1]);  // separate out the mime component  const mimeString = dataURI    .split(',')[0]    .split(':')[1]    .split(';')[0];  // write the bytes of the string to a typed array  const ia = new Uint8Array(byteString.length);  for (let i = 0; i < byteString.length; i++) {    ia[i] = byteString.charCodeAt(i);  }  return new Blob([ia], { type: mimeString });},

構建Form上傳表單

const blob = dataURItoBlob(imgDataUrl);const formData = new FormData();// formData.append('auth', state.token.auth); 可以選擇性的加入一些鑒權formData.append('file', blob);進行數據上傳,我這里使用的是axiosconst params = {   url: '/store/file',   payload: formData }; const data = await this.upload(params);

我已經對axios進行了封裝

export const upload = (params) => {  const { url, payload } = params  return axios.post(url, payload, {    headers: {      'Content-Type': 'multipart/form-data'    }  }).then(x => x.data)}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 固镇县| 莱阳市| 育儿| 遂川县| 固安县| 喀什市| 隆德县| 益阳市| 黔南| 基隆市| 呼玛县| 遂川县| 青冈县| 承德市| 巩留县| SHOW| 叙永县| 闽侯县| 濮阳县| 武乡县| 合江县| 鄂尔多斯市| 五华县| 时尚| 石家庄市| 商水县| 哈尔滨市| 南澳县| 冷水江市| 罗江县| 五莲县| 长兴县| 丽水市| 舟山市| 仪征市| 乌兰县| 安图县| 平乐县| 会东县| 洛浦县| 白银市|