react native上传二进制图片、视频的方法

react native获取本地图片我用的react-native-image-picker,但是它只能获取图片路径,以及base64的图片,不能获取到binary二进制形式的。

一开始我是让后端改造接口,把原本传binary的改成了base64,可是,躲得了初一躲不过十五。

上传视频是不可能走base64这种取巧的途径,于是,怎么把媒体文件转成binary给后端就成为了跨不过的坎。

找了好久的资料,总是能得到以下的的回答:

javascript 复制代码
  let formData = new FormData();
  let file = { uri: uri, type: 'multipart/form-data', name: 'a.jpg' };
  formData.append("images", file);
  fetch(url, {
    method: 'POST',
    headers: {
      'Content-Type': 'multipart/form-data',
    },
    body: formData,
  })
    .then((response) => response.text())
    .then((responseData) => {
      console.log('responseData', responseData);
    })
    .catch((error) => { console.error('error', error) });

首先这段代码我尝试了许多次都无法把它用multipart/form-data传输,后来发现,不写Content-Type它默认倒是识别正确了!然而第二个问题我始终无法解决,就是uri通过picker拿到的只是个路径,后端是无法将这本地路径去识别成文件的,试了无数次后最终将其放弃。

所以又回到了如何把媒体文件转成binary的问题上。(使用:react-native-fs不知道行不行得通,没试过)反正const response = await fetch(FILE_LOCAL_URL); const blob = await response.blob();是行不通的。

最终,我还是通过npm搜索react native blob找到了组件:react-native-blob-util,通过它的API,总算是把文件成功传给后端接口识别了:

javascript 复制代码
import { getHeader } from './common';
import { launchImageLibrary } from 'react-native-image-picker';
import { base } from '~/utils/base';
import ReactNativeBlobUtil from 'react-native-blob-util';

/** 上传图片获取url */
export function fetchUpload(fileModular, cb, isVideo) {
  launchImageLibrary({ mediaType: isVideo ? 'video' : 'photo' }, async res => {
    const curFiles = res.assets;
    if (curFiles) {
      const m = curFiles[0];
      if (m.fileSize > 1024 * 1024 * 10) {
        base.fail('图片过大,请上传10MB以内的图片');
      } else {
        base.load();
        const headers = await getHeader('multipart/form-data');
        ReactNativeBlobUtil.fetch('POST', `${global.api}/api/upload`, {
          ...headers,
        }, [
          { name: 'file', filename: m.fileName, type: m.type, data: ReactNativeBlobUtil.wrap(m.uri) },
          { name: 'fileModular', data: fileModular },
        ]).then((res) => {
          const json = JSON.parse(res.data)
          cb(json.data.res);
        }).catch((err) => {
          console.log(err)
        }).finally(() => {
          base.stop();
        })
      }
    } else {
      base.fail('请选择图片');
    }
  })
}
相关推荐
憧憬成为web高手1 小时前
ACTF 12307复现
前端·bootstrap·html
wordbaby2 小时前
Axios 上传大文件崩溃:鸿蒙 RNOH 下 XHR 返回空响应头引发的"假失败"
前端·react native
wordbaby2 小时前
React Native 列表分页实战:下拉刷新与上拉加载的工程化方案
前端·react native
wordbaby2 小时前
脱离 Tab 栏的艺术:React Native 全屏子页面的导航架构实践
前端·react native·harmonyos
陈随易3 小时前
Redis 8.8发布,一定要更新
前端·后端·程序员
wordbaby3 小时前
React Native 新架构落地鸿蒙:跨三端政务级应用的工程实践与深度复盘
前端·react native·harmonyos
晓说前端3 小时前
第一篇:为什么学TypeScript?—— 优势、场景与环境搭建
javascript·ubuntu·typescript
excel4 小时前
为什么我推荐使用 Termius:现代 SSH 工具的完整体验
前端·后端
ZC跨境爬虫4 小时前
模块化烹饪小程序开发日记 Day7:(菜谱详情接口开发与JSON数据读取全流程)
前端·javascript·css·ui·微信小程序·json
এ慕ོ冬℘゜5 小时前
JS 前端基础面试题
开发语言·前端·javascript