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

首頁 > 開發 > HTML5 > 正文

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

2024-09-05 07:22:55
字體:
來源:轉載
供稿:網友

一些場景,比如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)}

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 禄劝| 乐安县| 岳阳市| 乌拉特后旗| 柘城县| 宣武区| 台前县| 茌平县| 新闻| 连云港市| 永靖县| 交城县| 商都县| 浮山县| 永吉县| 印江| 当雄县| 杂多县| 团风县| 云和县| 海淀区| 仙居县| 玛曲县| 珲春市| 连南| 内黄县| SHOW| 霍山县| 鹰潭市| 平江县| 西华县| 遂昌县| 西丰县| 应城市| 唐河县| 溧阳市| 汉中市| 沂水县| 拜城县| 齐齐哈尔市| 久治县|