admin管理员组文章数量:1022688
I have an image in Base64 format. I want to send it to the API using formdata. How can that be achieved? I am using React native signature canvas to get the Base64 of the signature.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature,
name: 'logo',
filename: 'logo',
type: 'image/png',
});
I followed this link as well but don't understand how to send it to the API as formdata. It's constantly giving network errors.
I have also tried to convert it to a blob and send but that didn't work either. Can anyone help me with this?
I have an image in Base64 format. I want to send it to the API using formdata. How can that be achieved? I am using React native signature canvas to get the Base64 of the signature.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature,
name: 'logo',
filename: 'logo',
type: 'image/png',
});
I followed this link as well but don't understand how to send it to the API as formdata. It's constantly giving network errors.
I have also tried to convert it to a blob and send but that didn't work either. Can anyone help me with this?
Share Improve this question edited Sep 14, 2023 at 14:00 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked Jan 23, 2022 at 18:10 YusYus 1841 gold badge7 silver badges17 bronze badges 4- Could you add the code that you tried? – MaartenDev Commented Jan 23, 2022 at 18:12
- I have added the code above. – Yus Commented Jan 23, 2022 at 18:19
-
No, the code that transforms the base64-encoded string to a
File
object. Please also include the error message(s) in your question – Phil Commented Jan 24, 2022 at 5:55 -
The object you're appending to your
formData
isn't any of the acceptable parameter types. It must be be "aUSVString
orBlob
(including subclasses such asFile
)" – Phil Commented Jan 24, 2022 at 5:59
3 Answers
Reset to default 2var imgBase64 = "..." //your bse64 image
onSubmit(){
const file = DataURIToBlob(imgBase64)
const formData = new FormData();
formData.append('upload', file, 'image.jpg')
formData.append('profile_id', this.profile_id) //other param
formData.append('path', 'temp/') //other param
}
function DataURIToBlob(dataURI: string) {
const splitDataURI = dataURI.split(',')
const byteString = splitDataURI[0].indexOf('base64') >= 0 ? atob(splitDataURI[1]) : decodeURI(splitDataURI[1])
const mimeString = splitDataURI[0].split(':')[1].split(';')[0]
const ia = new Uint8Array(byteString.length)
for (let i = 0; i < byteString.length; i++)
ia[i] = byteString.charCodeAt(i)
return new Blob([ia], { type: mimeString })
}
The easiest way without external libraries.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature, // base64
name: 'logo.png',
type: 'image/png',
});
await axios.post('/', formdata, {headers: {'Content-Type': 'multipart/form-data'}})
- You need to install
react-native-fs
import RNFS from 'react-native-fs';
import {Platform} from 'react-native';
const createTempImage = async base64String => {
try {
let base64 = base64String.replace('data:image/png;base64,', '');
const fileName = `${Date.now()}.png`;
const path = `${RNFS.TemporaryDirectoryPath}/${fileName}`;
await RNFS.writeFile(path, base64, 'base64');
const image = {
uri: Platform.OS == 'ios'? path: 'file://' + path,
name: fileName,
type: 'image/png',
};
return image
} catch (error) {
console.log(error);
}
};
I have an image in Base64 format. I want to send it to the API using formdata. How can that be achieved? I am using React native signature canvas to get the Base64 of the signature.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature,
name: 'logo',
filename: 'logo',
type: 'image/png',
});
I followed this link as well but don't understand how to send it to the API as formdata. It's constantly giving network errors.
I have also tried to convert it to a blob and send but that didn't work either. Can anyone help me with this?
I have an image in Base64 format. I want to send it to the API using formdata. How can that be achieved? I am using React native signature canvas to get the Base64 of the signature.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature,
name: 'logo',
filename: 'logo',
type: 'image/png',
});
I followed this link as well but don't understand how to send it to the API as formdata. It's constantly giving network errors.
I have also tried to convert it to a blob and send but that didn't work either. Can anyone help me with this?
Share Improve this question edited Sep 14, 2023 at 14:00 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked Jan 23, 2022 at 18:10 YusYus 1841 gold badge7 silver badges17 bronze badges 4- Could you add the code that you tried? – MaartenDev Commented Jan 23, 2022 at 18:12
- I have added the code above. – Yus Commented Jan 23, 2022 at 18:19
-
No, the code that transforms the base64-encoded string to a
File
object. Please also include the error message(s) in your question – Phil Commented Jan 24, 2022 at 5:55 -
The object you're appending to your
formData
isn't any of the acceptable parameter types. It must be be "aUSVString
orBlob
(including subclasses such asFile
)" – Phil Commented Jan 24, 2022 at 5:59
3 Answers
Reset to default 2var imgBase64 = "..." //your bse64 image
onSubmit(){
const file = DataURIToBlob(imgBase64)
const formData = new FormData();
formData.append('upload', file, 'image.jpg')
formData.append('profile_id', this.profile_id) //other param
formData.append('path', 'temp/') //other param
}
function DataURIToBlob(dataURI: string) {
const splitDataURI = dataURI.split(',')
const byteString = splitDataURI[0].indexOf('base64') >= 0 ? atob(splitDataURI[1]) : decodeURI(splitDataURI[1])
const mimeString = splitDataURI[0].split(':')[1].split(';')[0]
const ia = new Uint8Array(byteString.length)
for (let i = 0; i < byteString.length; i++)
ia[i] = byteString.charCodeAt(i)
return new Blob([ia], { type: mimeString })
}
The easiest way without external libraries.
let signature = base64signature;
const formdata = new FormData();
formdata.append('attachments', {
uri: signature, // base64
name: 'logo.png',
type: 'image/png',
});
await axios.post('/', formdata, {headers: {'Content-Type': 'multipart/form-data'}})
- You need to install
react-native-fs
import RNFS from 'react-native-fs';
import {Platform} from 'react-native';
const createTempImage = async base64String => {
try {
let base64 = base64String.replace('data:image/png;base64,', '');
const fileName = `${Date.now()}.png`;
const path = `${RNFS.TemporaryDirectoryPath}/${fileName}`;
await RNFS.writeFile(path, base64, 'base64');
const image = {
uri: Platform.OS == 'ios'? path: 'file://' + path,
name: fileName,
type: 'image/png',
};
return image
} catch (error) {
console.log(error);
}
};
本文标签: javascriptHow to upload Base64 data to a server using formdata React nativeStack Overflow
版权声明:本文标题:javascript - How to upload Base64 data to a server using formdata React native? - Stack Overflow 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://it.en369.cn/questions/1745532075a2154795.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论