javascript React Native 将 base64 图像保存到相册
声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow
原文地址: http://stackoverflow.com/questions/48134397/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me):
StackOverFlow
React Native save base64 image to Album
提问by NamNamNam
Third Party API return a "QR code image" in base64 encode,
I need save that image to User's Album.
第三方 API 以 base64 编码返回“二维码图像”,
我需要将该图像保存到用户相册。
- CamerRoll - not support saving base64 image to album
- React-Native-Fetch-Blob -
https://github.com/wkh237/react-native-fetch-blob
still looking into it - React-Native-fs -
https://github.com/itinance/react-native-fs
I am trying this now - There are few npm modules with very little Github star (<10)
- CamerRoll - 不支持将 base64 图像保存到相册
- React-Native-Fetch-Blob -
https://github.com/wkh237/react-native-fetch-blob
仍在调查中 - React-Native-fs -
https://github.com/itinance/react-native-fs
我现在正在尝试 - 很少有 npm 模块的 Github star 很少(<10)
the React-Native-Fetch-Blob maintainer gone missing, so no one answering Github Issue,
createFilefrom React-Native-Fetch-Blob Documentnot working as expected(not saving image into album)
React-Native-Fetch-Blob 维护者不见了,所以没有人回答 Github 问题,
createFile来自React-Native-Fetch-Blob 文档没有按预期工作(没有将图像保存到相册中)
import fetch_blob from 'react-native-fetch-blob';
// json.qr variable are return from API
const fs = fetch_blob.fs
const base64 = fetch_blob.base64
const dirs = fetch_blob.fs.dirs
const file_path = dirs.DCIMDir + "/some.jpg"
const base64_img = base64.encode(json.qr)
fs.createFile(file_path, base64_img, 'base64')
.then((rep) => {
alert(JSON.stringify(rep));
})
.catch((error) => {
alert(JSON.stringify(error));
});
Anyone deal with this problem before?
以前有人处理过这个问题吗?
How to save a base64 encode Image string to User album? (as a jpg or png file)
如何将 base64 编码的图像字符串保存到用户相册?(作为 jpg 或 png 文件)
because I fetchan API with no CORS header,
I can't debug it in Debug JS Remotely
Chrome would stop that request from happening,
因为我fetch的 API 没有 CORS 标头,
所以我无法在Debug JS Remotely
Chrome 中调试它会阻止该请求发生,
I have to run that on my Android Phone to make it work
(no CORS control on real phone)
我必须在我的 Android 手机上运行它才能使其工作
(真实手机上没有 CORS 控制)
I am planing use Clipboard save base64 string,
and hardcode it in my code,
to debug what's wrong with react-native-fetch-blobcreateFileAPI
我正在计划使用剪贴板保存 base64 字符串,
并将其硬编码到我的代码中,
以调试react-native-fetch-blobcreateFileAPI 有什么问题
采纳答案by tnyN
You can now use only react native fetch blob to achieve this.
您现在只能使用 react native fetch blob 来实现这一点。
Simply replace RNFS.writeFile with
只需将 RNFS.writeFile 替换为
RNFetchBlob.fs.writeFile(file_path, image_data, 'base64')
If you wish to view file in native OS viewer you can simply put
如果您希望在本机操作系统查看器中查看文件,您可以简单地将
if (isAndroid) {
RNFetchBlob.android.actionViewIntent(file_path, 'application/pdf');
} else {
RNFetchBlob.ios.previewDocument(file_path);
}
回答by Akshay Italiya
Remove  your base64 string
data:image/png;base64,在 base64 字符串中删除
var Base64Code = base64Image.split("data:image/png;base64,"); //base64Image is my image base64 string
const dirs = RNFetchBlob.fs.dirs;
var path = dirs.DCIMDir + "/image.png";
RNFetchBlob.fs.writeFile(path, Base64Code[1], 'base64')
.then((res) => {console.log("File : ", res)});
And then I solved my problem.
然后我解决了我的问题。
回答by NamNamNam
I solve the problem,
turn out I forgot  beginning of the string.
我解决了这个问题,
结果我忘记data:image/png;base64,了字符串的开头。
I remove it with following code
我用以下代码删除它
// json.qr is base64 string
var image_data = json.qr.split('data:image/png;base64,');
image_data = image_data[1];
and then save the image file
然后保存图像文件
import fetch_blob from 'react-native-fetch-blob';
import RNFS from 'react-native-fs';
const fs = fetch_blob.fs
const dirs = fetch_blob.fs.dirs
const file_path = dirs.DCIMDir + "/bigjpg.png"
// json.qr is base64 string "data:image/png;base64,..."
var image_data = json.qr.split('data:image/png;base64,');
image_data = image_data[1];
RNFS.writeFile(file_path, image_data, 'base64')
.catch((error) => {
alert(JSON.stringify(error));
});
I wrote a blog about this
我写了一篇关于这个的博客
回答by Sundari Ragavan
const path = `${RNFS.PicturesDirectoryPath}/My Album`;
await RNFS.mkdir(path);
return await fetch(uri)
.then(res => res.blob())
.then(image => {
RNFetchBlob.fs.readFile(uri, "base64").then(data => {
RNFS.appendFile(`${path}/${image.data.name}`, data, "base64").catch(
err => {
console.log("error writing to android storage :", err);
}
);
});
});
回答by Andrey Shostik
I got this worked in following example
我在下面的例子中得到了这个
import RNFetchBlob from 'rn-fetch-blob';
import Permissions from 'react-native-permissions';
takeSnapshot = async () => {
const currentStatus = await Permissions.check('storage');
if (currentStatus !== 'authorized') {
const status = await Permissions.request('storage');
if (status !== 'authorized') {
return false;
}
}
// put here your base64
const base64 = '';
const path = `${RNFetchBlob.fs.dirs.DCIMDir}/test11.png`;
try {
const data = await RNFetchBlob.fs.writeFile(path, base64, 'base64');
console.log(data, 'data');
} catch (error) {
console.log(error.message);
}
};

