鸿蒙Next开发之-保存base64图片到本地沙盒

前言

目前公司和华为达成了合作,计划在鸿蒙正式发布next版本之前,上架公司APP的鸿蒙版本。方便用户升级手机到鸿蒙next之后,能正常使用公司APP,保证用户的既得利益。

目前公司的项目大体架构如下:

整个APP使用的是跨平台解决方案:Flutter、Game(Unity&Cocos)、H5

跨平台通过Bridge SDK调用原生底座能力。

开发环境

  • Mac
  • DevEco Studio NEXT Developer Preview2
  • HarmonyOS next Developer Preview2

这篇文章浅谈一下,在鸿蒙next上,如何实现将base64字符串的图片保存到原生设备上。

Base64认知

什么是Base64

Base64 是一种基于64个 ASCII 字符来表示二进制数据的表示方法,这个64个不同的字符为:

  • 大、小写字母(A-- Za--z)。52个
  • 数字。(0--9)10个
  • 两个特殊字符。(+/)2个

参考:en.wikipedia.org/wiki/Base64...

Base64原理

  1. 将图片转换成二进制数据。
  2. 8比特位为一个单元的字节数据拆分为以6个比特位为一个单元的字节数据。
  3. 6个比特位为一个单元高位补齐00,补足8个比特。
  4. 如果剩余的字节不足6位,则先低位补00凑齐6位之后,高位再补00,补足8位。
  5. 当未编码(1中的二进制数据)输入的长度不是三的倍数时,则编码输出(3)必须添加填充,使其长度为四的倍数。填充字符为=
  6. 将补齐8个比特的二进制数据,转化为10进制数据。然后到上面的base64码表中进行查询,并生成字符。
  7. 将所有的字符进行拼接组成base64字符串。

举例说明

比如字符串:"byhk"

  1. 将其转换为二进制数据:01100010、01111001、01101000、01101011
  2. 将8比特拆为6比特:011000,100111,100101,101000,011010,11
  3. 高位补齐00,补足8个比特:0011000,0100111,00100101,00101000,00011010,00110000,
  4. 最后的11不满6位,先低位补0000变为:110000,然后高位补00,变为:00110000
  5. 步骤3,最后的数量不是4的倍数,因此需要填充两个=
  6. 因此"byhk"的base64的结果为:"Ynloaw=="

鸿蒙base64图片保存到本地沙盒

认识图片base64格式

bash 复制代码
data:image/png;base64,iVBORw0KGg....

1、解析图片数据

csharp 复制代码
private static dealBase64Str(base64Data: string): string {
  let imageData: string
  if (base64Data.startsWith("data")) {
    const base64Split: string[] = base64Data.split(",")
    if (base64Split.length !== 2) {
      throw new Error(`Illegal base64 data`)
    }
    imageData = base64Split[1].trim()
  } else {
    imageData = base64Data
  }
  return imageData
}

2、创建沙盒文件

typescript 复制代码
private static createFile(context: Context) {
  let pathDir = context.filesDir
  let fileName = systemDateTime.getTime(true)
  let filePath = `${pathDir}/${fileName}.jpg`
  let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE)
  return file
}

3、将图片数据写入

csharp 复制代码
let bufferImage = buffer.from(base64Result, 'base64')
await fs.write(file.fd, bufferImage.buffer)
fs.closeSync(file.fd)

完整代码

typescript 复制代码
export class ImageUtils {
  static async saveBase64Image(base64ImageData: string, context: Context): Promise<Boolean> {
    try {
      let base64Result = ImageUtils.dealBase64Str(base64ImageData)
      let file = ImageUtils.createFile(context)
      let bufferImage = buffer.from(base64Result, 'base64')
      await fs.write(file.fd, bufferImage.buffer)
      fs.closeSync(file.fd)
      return Promise.resolve(true)
    } catch (e) {
      throw new Error(e)
    }
  }

  private static dealBase64Str(base64Data: string): string {
    let imageData: string
    if (base64Data.startsWith("data")) {
      const base64Split: string[] = base64Data.split(",")
      if (base64Split.length !== 2) {
        throw new Error(`ImageUtils: Illegal base64 data`)
      }
      imageData = base64Split[1].trim()
    } else {
      imageData = base64Data
    }
    return imageData
  }

  private static createFile(context: Context) {
    let pathDir = context.filesDir
    let fileName = systemDateTime.getTime(true)
    let filePath = `${pathDir}/${fileName}.jpg`
    let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE)
    return file
  }
}
相关推荐
lqj_本人36 分钟前
鸿蒙electron跨端框架PC浮签实战:做一面轻巧但能回找的桌面便签墙
华为·harmonyos
ai安歌1 小时前
鸿蒙PC:Qt适配OpenHarmony实战【人名录】:单机联系人卡片,不读系统通讯录也能演示详情联动
数据库·qt·harmonyos
lqj_本人2 小时前
鸿蒙electron跨端框架PC简序实战:把轻任务、优先级和截止时间塞进一张桌面清单
华为·harmonyos
想你依然心痛3 小时前
HarmonyOS 6 悬浮导航 + 沉浸光感:打造鸿蒙智能体驱动的沉浸式智能家居控制中枢
华为·ar·智能家居·harmonyos·智能体
lqj_本人3 小时前
鸿蒙PC:Qt适配OpenHarmony实战【花账】:从一笔支出开始,做一个本地记账小应用
数据库·qt·harmonyos
递归4043 小时前
ofdkit-harmony 0.2.0 发布:鸿蒙原生 OFD 阅读库,已上架 ohpm
开源·harmonyos·arkts·ofd·ohpm
nashane4 小时前
HarmonyOS 6学习:SoundPool音频防抖与Web长截图时序重构
学习·音视频·harmonyos·harmonyos 5
Exploring5 小时前
鸿蒙App开发,华为手机里装这一个就够了——「Hola万能计算器」到底有多万能?
harmonyos
想你依然心痛5 小时前
HarmonyOS 6 悬浮导航 + 沉浸光感:打造鸿蒙智能体驱动的沉浸式数据可视化驾驶舱
华为·信息可视化·ar·harmonyos·智能体
lqj_本人16 小时前
鸿蒙electron跨端框架PC导出管家实战:把交付前的检查、复制和导出做成一个工坊
华为·electron·harmonyos