将base64字符串保存为图片的方法

将base64字符串保存为图片的方法


HarmonyOS
2024-07-30 11:05:01
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
躺平嗑产品懒猫

在数据处理过程中,为了将base64编码格式的字符串转换为可存储的文件内容,我们可以采用`buffer.from`方法,该方法允许我们创建新的Buffer对象。一旦获得了该Buffer对象,我们可以进一步利用`fileIo.writeSync`方法,确保以同步的方式将转换后的Buffer对象内容写入到指定的文件中。

import { buffer } from '@kit.ArkTS';
import { fileIo } from '@kit.CoreFileKit';
import { common } from '@kit.AbilityKit';
import { fileUri } from "@kit.CoreFileKit";
import { hilog } from '@kit.PerformanceAnalysisKit';

let context = getContext(this) as common.UIAbilityContext;
let filesDir = context.filesDir;

// data为需要转换的base64字符串,返回沙箱路径uri
export async function writeFile(data: string): Promise<string> {
  let uri = ''
  try {
    let filePath = filesDir + "/1.png";
    uri = fileUri.getUriFromPath(filePath);
    let file = fileIo.openSync(filePath, fileIo.OpenMode.READ_WRITE | fileIo.OpenMode.CREATE);
    console.info("file fd: " + file.fd);
    const reg = new RegExp("data:image/\\w+;base64,")
    const base64 = data.replace(reg, "");
    console.log("base64flag", base64)
    const dataBuffer = buffer.from(base64, 'base64')
    let writeLen = fileIo.writeSync(file.fd, dataBuffer.buffer);
    hilog.info(0xA0c0d0,'uri',uri)
    fileIo.closeSync(file);
  }
  catch (Error) {
    hilog.error(0xA0c0d0,'Error',Error.code)
  }
  return uri;
}
分享
微博
QQ
微信
回复
2024-07-30 17:05:37
相关问题
base64字符如何转为图片保存
2349浏览 • 1回复 待解决
如何PixelMap转图片base64字符
298浏览 • 1回复 待解决
如何图片base64字符转PixelMap?
418浏览 • 1回复 待解决
PixelMap类型怎么转换成Base64字符
333浏览 • 1回复 待解决
HarmonyOS如何图片Base64
679浏览 • 1回复 待解决
HarmonyOS 如何base64数据转换为图片
338浏览 • 1回复 待解决
HarmonyOS Image如何显示base64图片
180浏览 • 1回复 待解决
HarmonyOS 图片进行base64编码报错
397浏览 • 1回复 待解决
怎么把PixelMap图片BASE64
9163浏览 • 1回复 待解决
js canvas转base64编码图片不全
10502浏览 • 1回复 待解决
如何base64转换成图片
10008浏览 • 2回复 待解决