React Native Expo Как загрузить изображение в Firebase с помощью средства выбора изображений expo

Я пытаюсь загрузить изображение в свою firebase, но не могу понять.

это мой код

_pickImage = async () => {
    let result = await ImagePicker.launchImageLibraryAsync({
        mediaTypes: ImagePicker.MediaTypeOptions.All,
        allowsEditing: true,
        aspect: [4, 3],
        quality: 1
    });

    if (!result.cancelled) {
        this.uploadImage(result.uri, 'test-image')
            .then(() => {
                console.log('it work')
            })
            .catch(error => {
                console.log('it does not work')
                console.error(error)
            })
    }
};

uploadImage = async (uri, imageName) => {
    const response = await fetch(uri);
    const blob = response.blob();

    const ref = firebase.storage().ref().child(`images/${imageName}`);
    return ref.put(blob);
}

Я получаю эту ошибку.

FirebaseStorageError {
 "code_": "storage/invalid-argument",
 "message_": "Firebase Storage: Invalid argument in `put` at index 0: Expected Blob or File.",
 "name_": "FirebaseError",
 "serverResponse_": null,
}

person Millenial2020    schedule 04.01.2020    source источник


Ответы (2)


Используйте этот код:

`const blob = await response.blob();`

Вместо:

const blob = response.blob();

чтобы решить вашу проблему.

person Hasintha Jayasinghe    schedule 08.08.2020

попробуй var ref= firebase.storage().ref().child('images/'+imageName) вместо своего

person Rorschach Prime    schedule 15.02.2020