国产探花免费观看_亚洲丰满少妇自慰呻吟_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)}

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黄山市| 凤阳县| 阿巴嘎旗| 辉县市| 南华县| 遂宁市| 平武县| 蒙城县| 和平区| 富蕴县| 洞头县| 安塞县| 乌拉特前旗| 柳州市| 禄丰县| 芜湖市| 丹东市| 东乌珠穆沁旗| 阿坝县| 忻城县| 成都市| 湖州市| 绥芬河市| 浮梁县| 马山县| 安岳县| 清苑县| 洛阳市| 观塘区| 容城县| 佛教| 武安市| 海林市| 金山区| 沿河| 沙湾县| 沂源县| 白城市| 离岛区| 井冈山市| 宝山区|