2

我正在使用 RNFetchBlob 将图像从本地(ios)文件系统上传到 Firebase

虽然我的图像正在被删除,但我的 blob 在关闭后仍保留在文件系统中。我尝试取消链接 blob,但它仍然存在

function createBlob(uri, mediaType) {
  const Blob = RNFetchBlob.polyfill.Blob; 
  const typePrefix = isImage(mediaType) ? 'image' : 'video';  
  window.Blob = Blob;
  window.XMLHttpRequest = RNFetchBlob.polyfill.XMLHttpRequest;  

  return new Promise((resolve, reject) => {
    const uid = guid();
    const mediaRef = firebase.storage().ref('users').child(`${uid}.${mediaType}`);
    let uploadBlob = null;

    Blob.build(uri, { type: `${typePrefix}/${mediaType}` })
    .then((blob) => {
      uploadBlob = blob;
      return mediaRef.put(blob, { type: `${typePrefix}/${mediaType}` });
    })
    .then((response) => {
      uploadBlob.close();

      resolve(response);
    })
    .catch(error => {
      reject(error);
    });
  });
}

这是关闭 blob 后它在我的模拟器文件夹中的外观

在此处输入图像描述

createBlob我使用从本地存储中删除文件之后RNFetchBlob.fs.unlink(path)

4

1 回答 1

2

我不认为你正在close()工作,因为uploadBlob变量是在上一个闭包中创建的,但没有传递到下一个.then块。我想这可能会奏效...

Blob.build(uri, { type: `${typePrefix}/${mediaType}` })
.then((blob) => {
  uploadBlob = blob;
  return ({
     response: mediaRef.put(blob, { type: `${typePrefix}/${mediaType}` }),
     blob: uploadBlob
})
.then(({response, blob}) => {
  blob.close();

  resolve(response);
})
于 2017-12-09T04:06:07.217 回答