繁体   English   中英

从 react-native 获取文件以上传与 ` 相同的图像<input type="file" onChange={this.fileChangedHandler}> `

[英]Get file from react-native to upload image same as `<input type="file" onChange={this.fileChangedHandler}> `

我试过做

var photo = {
    uri: uriFromCameraRoll,
    type: 'image/jpeg',
    name: 'photo.jpg',
};

并使用

公理

var body = new FormData();
body.append('authToken', 'secret');
body.append('photo', photo);
body.append('title', 'A beautiful photo!');

const config = {
            headers: {
                'content-Type': 'multipart/form-data'
            }
        }
 MY_API().then(instance => {

// it is axios instance
            instance.post("/api/v1/upload",
                { body }
                , config).then(res => {
                    console.log(JSON.stringify(res));

                }).catch(err => {
                    console.log(err);
                })
        }
        )

在删除配置我得到

错误 503

并通过配置它给出

错误:多部分:未找到边界

并且与 POSTMAN 一起工作也很好......连同标题

我也尝试上传 File (blob) ,但同样的错误

错误:多部分:未找到边界

 dataURLtoFile(dataurl, filename) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new File([u8arr], filename, {type:mime});
}

//Usage example:
var file = dataURLtoFile('data:text/plain;base64,aGVsbG8gd29ybGQ=', 'hello.txt');
console.log(file);

API 在带有代码的 ReactJS 中运行良好在此处输入图片说明

编辑:我已经通过使用React-native-fetch-blob解决了这个问题,但希望使用 axios 来解决,

这是代码:

 RNFetchBlob.fetch('POST', 'https://helloapp.herokuapp.com/api/v1/upload', {
            'authorization': jwtToken,
            'Content-Type': 'multipart/form-data',
        },
            [
                { name: 'image', filename: 'avatar-png.png', type: 'image/png', data: base64logo },
                { name: 'name', data: name }
            ]
        ).then((resp) => {
            console.log(resp);
        }).catch((err) => {
            console.log(err);
        });

我已经通过使用React-native-fetch-blob解决了这个问题,但希望使用 axios 来解决,

这是代码:

 RNFetchBlob.fetch('POST', 'https://helloapp.herokuapp.com/api/v1/upload', {
            'authorization': jwtToken,
            'Content-Type': 'multipart/form-data',
        },
            [
                { name: 'image', filename: 'avatar-png.png', type: 'image/png', data: base64logo },
                { name: 'name', data: name }
            ]
        ).then((resp) => {
            console.log(resp);
        }).catch((err) => {
            console.log(err);
        });

永远不要在发送文件时定义内容类型标头。 浏览器/邮递员会自动添加它,看起来像这样。

Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7BojnnMEteO0aHWP

表单边界是表单数据的分隔符。 发送请求时会计算边界,因此您无法对其进行硬编码。

这就是为什么您找不到错误边界的原因。

现在你可以使用 fetch , axios 任何东西,它会起作用。

这是非常重要的信息,在 MDN Fetch 文档中没有记录

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM