uniapp APP读取bin文件(仅测试安卓可用)

1.解析bin文件内容

javascript 复制代码
    getData(path) {
      return new Promise(
        (resolve) => {
          uni.downloadFile({
            url: path, // .bin 文件 URL
            success: (res) => {
              if (res.statusCode === 200) {
                //文件读写是一个异步请求 用promise包起来方便使用时的async+await
                plus.io.resolveLocalFileSystemURL(
                  res.tempFilePath, //请求文件系统
                  (fileEntry) => {
                    fileEntry.file(function (file) {
                      let fileReader = new plus.io.FileReader(); //new一个可以用来读取文件的对象fileReader
                      fileReader.readAsDataURL(file); //读文件的格式
                      fileReader.onerror = (e) => {
                        //读文件失败
                        console.log("获取文件失败", fileReader.error);
                        return;
                      };
                      fileReader.onload = (e) => {
                        //读文件成功
                        var u8arr = (function (path, name) {
                          var arr = path.split(","),
                            mime = arr[0].match(/:(.*?);/)[1],
                            bstr = atob(arr[1]),
                            n = bstr.length,
                            u8arr = new Uint8Array(n);
                          while (n--) {
                            u8arr[n] = bstr.charCodeAt(n);
                          }
                          resolve(u8arr);
                        })(e.target.result, fileEntry.name);
                      };
                    });
                  },
                  (error) => {
                    console.log("新建获取文件失败", error);
                    return;
                  }
                );
              }
            },
            fail: (err) => {
              console.log("下载失败:", err);
            },
          });
        },
        (failure) => {
          console.log("请求文件系统失败", failure.message);
          return;
        }
      );
    },

2.使用

javascript 复制代码
 let pathUrl = '你的在线.bin文件地址'
 this.getData(pathUrl).then((res) => {
    // arrayBuffer 文件
    console.log(res);
    // 转16进制
    let hex = this.arraybufferTo2Hex(res);
    console.log(hex);
 });



 // 转16进制
 arraybufferTo2Hex(buffer) {
   return Array.prototype.map
      .call(new Uint8Array(buffer), (x) => ("00" + x.toString(16)).slice(-2))
      .join(" ");
 },
相关推荐
大家的林语冰13 小时前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
逐光老顽童15 小时前
Java 与 Kotlin 混合开发避坑指南:30 个真实案例实录
android·kotlin
weedsfly15 小时前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户17335980753715 小时前
纯前端 PDF 数字签名实战:Vue 3 + pdf-lib 在浏览器里完成签名嵌入
前端·javascript
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
爱勇宝1 天前
鸿蒙生态的下半场:开发者不只要能开发,还要能赚钱
android·前端·程序员
kyriewen1 天前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher1 天前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
Yeyu1 天前
刷新一帧的艺术:invalidate / postInvalidate / postInvalidateOnAnimation全解析
android