rn-fetch-blob Ошибка: RNFetchBlob.fetchBlobForm не удалось создать тело запроса
async postFileUpload(payload) {
const rnfetchfile = RNFetchBlob.wrap(payload.uri);
try {
console.log(
'POST',
'https://******.***.**/******/***/upload_*******_file',
{
...this.config,
'Content-Type': 'multipart/form-data',
},
[
// element with property `filename` will be transformed into `file` in form data
{
name: 'files',
filename: payload.name,
data: rnfetchfile.replace('file://file:///', 'file://'),
},
],
);
const res = await RNFetchBlob.fetch(
'POST',
'https://******.***.**/******/***/upload_*******_file',
{
...this.config,
'Content-Type': 'multipart/form-data',
},
[
// element with property `filename` will be transformed into `file` in form data
{
name: 'files',
filename: payload.name,
data: rnfetchfile.replace('file://file:///', 'file://'),
},
],
);
const response = JSON.parse(res.data);
console.log('api upload adpostimage', response);
return response;
} catch (err) {
console.log('postFileUpload', err.response, err);
Toast.show(err.response.data.message, Toast.SHORT);
throw err.response.data;
}
res выдает ошибку в сообщениях консоли
POST https://******.***.**/******/***/upload_*******_file {Content-Type: "multipart/form-data", Authorization: "Bearer ******.***.*****"}
[{…}]
0:
name: "files"
filename: "*****.pdf"
data: "RNFetchBlob-file://Users/********/tmp/*****/B****.pdf"}
postFileUpload undefined Error: RNFetchBlob.fetchBlobForm failed to create request body
at index.js:313
at MessageQueue.__invokeCallback (MessageQueue.js:483)
at MessageQueue.js:135
at MessageQueue.__guard (MessageQueue.js:384)
at MessageQueue.invokeCallbackAndReturnFlushedQueue (MessageQueue.js:134)
at debuggerWorker.js:69
Я пытаюсь загрузить файл с помощью rn-fetch-blob, и произошли сумасшедшие вещи rnfetchfile.replace ('file: // file: ///', 'file: //') из-за file: // file / // вывод, который казался неправильным, я думаю, это в основном проблема с iOS, пожалуйста, помогите мне, ребята
2 ответа
Как здесь сказано, просто используйтеdecodeURIComponent(uri)
это мой код:
const realPath = Platform.OS === 'ios' ? uri.replace('file://', '') : uri;
const data = [
{
name: 'file',
filename,
type,
data: RNFetchBlob.wrap(decodeURIComponent(realPath)),
},
{name: 'bla', data: 'bla'}
]
Попробуйте заменить file://file:// на пустую строку..
rnfetchfile.replace('file://file:///', '')
- @Abhishek Ghosh прокомментировал, что это необходимая уловка, которая будет работать, но файл не будет доступен в URI.. ваш загруженный файл не откроется
Я пробовал делать
data: decodeURIComponent(rnfetchfile.replace('file://file:///', 'file:///')
и это сработало, надеюсь, это поможет