国产探花免费观看_亚洲丰满少妇自慰呻吟_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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 芒康县| 河池市| 治县。| 宁乡县| 孝感市| 澄迈县| 乌鲁木齐市| 诸城市| 仪征市| 社会| 景东| 万全县| 利辛县| 三门峡市| 蓝山县| 新邵县| 万山特区| 宽城| 海晏县| 扶沟县| 苍山县| 清原| 清丰县| 文化| 耒阳市| 彰武县| 陆川县| 陆良县| 西吉县| 海安县| 玉山县| 沙坪坝区| 梁平县| 湖口县| 横山县| 湛江市| 仲巴县| 杭锦旗| 肇庆市| 淄博市| 无棣县|