1uniAPP中拿到附件的base64如何操作,如word文件

/**
* 实现思路:
* 通过native.js的io操作创建文件,拿到平台绝对路径
* 再通过原生类进行base64解码,拿到字节流bytes数组需注意官方的android.util.Base64的 Base64.decode(base64Str,0)有大小限制;目前解决方案写了个原生插件Helper
* 在通过java类FileOutputStream进行文件写入bytes返回文件路径path
* 在通过plus.runtime.openFile(path);用第三方程序打开文件
* */

第一步:解决android.util.Base64的 Base64.decode(base64Str,0)有大小限制

引入原生插件Helper插件在附件里https://pan.baidu.com/s/1hXhdSWXdZStYjAbgMzvFfw 提取码 加我qq 1392293229

// 文件操作
const Helper = uni.requireNativePlugin('Helper')

第二步:封装文件写入操作lzFileWriter函数

//文件的写入操作传入要写入文件名,base64
function lzFileWriter(base64,fileName) {
return new Promise((result,reject)=>{
// PRIVATE_WWW:本地文件系统常量,Number类型,固定值1。应用运行资源目录,仅本应用可访问。 为了确保应用资源的安全性,此目录只可读。
// PRIVATE_DOC 本地文件系统常量,Number类型,固定值2。应用私有文档目录,仅本应用可读写。
plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
/*
fs.root是根目录操作对象DirectoryEntry
getFile(path,flag,succesCB,errorCB)创建或打开文件
path: ( DOMString ) 必选 要操作文件相对于当前目录的地址
flag: ( Flags ) 可选 要操作文件或目录的参数 create: (Boolean 类型 )是否创建对象标记 指示如果文件或目录不存在时是否进行创建,默认值为false
succesCB: ( EntrySuccessCallback ) 可选 创建或打开文件成功的回调函数
errorCB: ( FileErrorCallback ) 可选 创建或打开文件失败的回调函数
*/
// 创建或打开文件
fs.root.getFile(fileName,{create:true},function(fileEntry) {
// 获得平台绝对路径
var fullPath = fileEntry.fullPath;
console.log('平台绝对路径',fullPath);
// 引入安卓原生类
// var Base64 = plus.android.importClass("android.util.Base64");
var FileOutputStream = plus.android.importClass("java.io.FileOutputStream");
//如果文件不存在则创建文件,如果文件存在则删除文件后重新创建文件
var out = new FileOutputStream(fullPath);
/**
* 此处需要把base64前缀去除,解码后,在写入字节流数组
* 去除头部如data:image/jpg;base64,留下base64编码后的字符串
**/
let index=base64.indexOf(',')
let base64Str=base64.slice(index+1,base64.length)
//base64编码的字符串获取bytes字节流,此bytes为编码的
let bytes = Helper.Str2Bytes(base64Str,'utf-8').data;
/**
* bytes再去解密,得到原始的字节流bytes
* 由于使用njs的android.util.Base64的var bytes = Base64.decode(base64Str,0);解码有大小限制,只能写原始插件Helper
**/
bytes=Helper.Base64Decode(bytes,0).data;
/**
* base64解密得到字节流bytes;但是njs有大小限制,解码不能超过100kb具体与手机系统版本有关
* Base64.decode(base64Str,0);此方法相当于上面的操作
* 【let bytes = Helper.Str2Bytes(base64Str,'utf-8').data; bytes=Helper.Base64Decode(bytes,0).data;】
**/
// var bytes = Base64.decode(base64Str,0);//有大小限制已舍弃此方法
try{
out.write(bytes); // byte 数组写入此文件输出流中。
out.flush(); //刷新写入文件中去。
out.close(); //关闭此文件输出流并释放与此流有关的所有系统资源。
result(fullPath)
}catch(e){
console.log(e.message);
reject(e.message)
}
// 下面的方法只能写入字符串,无法写入字节流bytes
// fileEntry文件系统中的文件对象,用于管理特定的本地文件
// fileEntry.file(function(file) {
// /*createWriter获取文件关联的写文件操作对象FileWriter
// abort: 终止文件写入操作
// seek: 定位文件操作位置
// truncate: 按照指定长度截断文件
// write: 向文件中写入数据
// */
// fileEntry.createWriter(function(FileWriter) {
// FileWriter.write(base64);
// FileWriter.onwriteend=function(res){
// console.log(res.target.fileName);
// result(res.target.fileName)
// }
// FileWriter.onerror=function(error){
// console.log(error);
// reject(error)
// }
// }, function(e) {
// console.log(e);
// });
// });
});
});
})
}

第三步调用封装的lzFileWriter

/**
* 实现思路:
* 通过native.js的io操作创建文件,拿到平台绝对路径
* 再通过原生类进行base64解码,拿到字节流bytes数组
* 在通过java类FileOutputStream进行文件写入bytes返回文件路径path
* 在通过plus.runtime.openFile(path);用第三方程序打开文件
* */
// 写入字节输出流
let path=await that.$lizhao.lzfile.lzFileWriter(base64,'lizhao222.doc')
console.log(path);
plus.runtime.openFile(path);

2.拿到视频,音频,图片的base64如何操作?

/**
* 实现思路:
* 视频和音频拿到base64,可通过h5方式将base64转成blob对象
* 再通过URL.createObjectURL(blob)生成指向File对象或Blob对象的URL,
* 此url可以放到大部分标签下的src中进行渲染,如img,video,audio
* */

第一步:新建一个vue页面传入base64,创建webview

create(){
let that=this
var currentWebview = this.$scope.$getAppWebview()
//创建Webview窗口,用于加载新的HTML页面,可通过styles设置Webview窗口的样式,创建完成后需要调用show方法才能将Webview窗口显示出来。
let wv = plus.webview.create("/hybrid/html/pages/filePlay.html","/hybrid/html/pages/filePlay.html",{
'uni-app': 'none', //不加载uni-app渲染层框架,避免样式冲突
top: 0,
height: '100%',
background: 'transparent'
},{
base64:that.base64,//传参
type:that.type//文件类型
});
// 在Webview窗口中添加子窗口// ${that}.bbb(objecturl)
currentWebview.append(wv);
},

第二步:在filePlay.html中拿到base64

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>文件播放系统</title>
<style type="text/css">
html,
body {
padding: 0;
margin: 0;
} #App {
background: transparent;
width: 100vw;
height: 100vh;
display: flex;
flex-direction: column;
} #App .video {
width: 100%;
height: 100%;
} #App .audio {
margin: auto;
}
</style>
</head>
<body>
<div id="App">
<video :src="videoSrc" autoplay v-if="videoSrc" controls class="video"></video>
<!-- <img :src="imgSrc" v-if="imgSrc"/> -->
<audio id="myAudio" controls v-if="audioSrc" class="audio">
<source :src="audioSrc" type="audio/ogg">
<source :src="audioSrc" type="audio/mpeg">
暂不支持播放此类型
</audio>
<iframe :src='wordSrc' width='100%' height='100%' frameborder='1' v-if="wordSrc"></iframe>
</div>
<!-- uni 的 SDK -->
<script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>
<script type="text/javascript" src="../js/vue.js"></script>
<script type="text/javascript" src="../js/global.js"></script>
<script type="text/javascript" src="../js/file-saver/dist/FileSaver.js"></script>
<!-- <script type="text/javascript" src="../js/wps/web-office-sdk-v1.1.2.umd.js"></script> -->
<script type="text/javascript">
// import { saveAs } from '../js/file-saver/dist/FileSaver.js';
document.addEventListener('UniAppJSBridgeReady', function() {
let that
//webview传参到html5网页
let {
base64,
type
} = plus.webview.currentWebview();
console.log(base64.slice(0, 50));
new Vue({
el: '#App',
data: {
videoSrc: '',
imgSrc: '',
audioSrc: '',
wordSrc: '',
aHref: ""
},
async mounted() {
that = this
let blob = that.dataURLtoBlob(base64)
/**
* URL对象用于生成指向File对象或Blob对象的URL。
* 这个URL可以放置于任何通常可以放置URL的地方,比如img标签的src属性
**/
var blobUrl = URL.createObjectURL(blob);
console.log(blobUrl);
console.log(type);
if (type == 'video') {
that.videoSrc = blobUrl
} else if (type == 'audio') {
that.audioSrc = blobUrl
} else if (type == 'word') {
}
// 在每次调用createObjectURL()方法时,都会创建一个新的URL对象,即使你已经用相同的对象作为参数创建过。当不再需要这些URL对象时,每个对象必须通过调用URL.revokeObjectURL()方法来释放
setTimeout(() => {
window.URL.revokeObjectURL(objecturl); //释放createObjectURL创建得对象
}, 2000) },
methods: {
//base64转成blob对象第一种方式
dataURLtoBlob(dataurl) {
var arr = dataurl.split(','),
mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[1]),
n = bstr.length,
u8arr = new Uint8Array(n);//8位无符号整数,长度1个字节
console.log(mime)
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
// console.log(JSON.stringify(u8arr));
return new Blob([u8arr], {
type: mime
});
}, }
})
});
</script>
</body>
</html>

  

uniapp中拿到base64转blob对象,或base64转bytes字节数组,io操作写入字节流文件bytes的更多相关文章

  1. JS实现图片base64转blob对象,压缩图片,预览图片,图片旋转到正确角度

    base64转blob对象 /** 将base64转换为文件对象 * @param {String} base64 base64字符串 * */ var convertBase64ToBlob = f ...

  2. Python中的文件IO操作(读写文件、追加文件)

    Python中文件的读写包含三个步骤:打开文件,读/写文件,关闭文件. 文件打开之后必须关闭,因为在磁盘上读写文件的功能是由操作系统提供的,文件作为对象,被打开后会占用操作系统的资源,而操作系统在同一 ...

  3. 简述ADO中如何使用参数化的命令对象以及增删改查,存储过程的操作

    连接数据库代码: private SqlConnection con = null; public void OpenConnection(string connectionString) { con ...

  4. delphi中如何将string类型的字符串数据转化成byte[]字节数组类型的数据

    var  S:String;  P:PChar;  B:array of Byte;begin  S:='Hello';  SetLength(B,Length(S)+1);  P:=PChar(S) ...

  5. MP4视频流base64数据转成Blob对象

    网上一大堆对图片base64转Blob.File的方法 很少有视频mp4转的,可能是因为原理相同的原因吧!但在项目中针对视频流base64转Blob对象时,花了好长时间才成功,特专门记录一下! APP ...

  6. 『现学现忘』Git对象 — 15、blob对象介绍

    目录 (一)Git对象的存放目录 (二)Git中对象类型 (三)blob对象 1.blob对象说明 (1)blob对象定义 (2)blob对象说明 (3)blob对象存储的方式 (4)查看blob对象 ...

  7. 6.5(java学习笔记)其他流(字节数组流,数据流,对象流,打印流)

    一.字节数组流 之前使用输入输出流的操作的对象是文件,而这里字节数组流操作的对象是内存,内存可以看做是一个字节数组. 使用字节数组流读写就可以看做是从内存A到内存B的读写,对象时内存即字节数组. 1. ...

  8. python文件对象几种操作模式区别——文件操作方法详解

    文件对象的字节模式/b模式(以utf-8编码为例) 读操作 写操作 指针操作 ASCII字节 返回bytes/字节类型的Ascii 写入bytes类型字节 例如:b'This is ascii' 使用 ...

  9. [.Net,C#]三类资源:流对象Stream,字节数组byte[],图片Image

    三类资源:流对象Stream,字节数组byte[],图片Image 关系:Stream<=>byte[],byte[]<=>Image Stream 与Image相互转化的媒介 ...

随机推荐

  1. Java读文件写入kafka

    目录 Java读文件写入kafka 文件格式 pom依赖 java代码 Java读文件写入kafka 文件格式 840271 103208 0 0.0 insert 84e66588-8875-441 ...

  2. 利用python代码获取文件特定的内容,并保存为文档

    说明:有段时间需要读取上百个文件的单点能(sp),就写了下面的代码(计算化学狗努力转行中^-^) import os.path import re # 1 遍历指定目录,显示目录下的所有文件名 def ...

  3. Linux基础命令---ntpq查询时间服务器

    ntpq ntpq指令使用NTP模式6数据包与NTP服务器通信,能够在允许的网络上查询的兼容的服务器.它以交互模式运行,或者通过命令行参数运行. 此命令的适用范围:RedHat.RHEL.Ubuntu ...

  4. 双向链表——Java实现

    双向链表 链表是是一种重要的数据结构,有单链表和双向链表之分:本文我将重点阐述不带头结点的双向链表: 不带头结点的带链表 我将对双链表的增加和删除元素操作进行如下解析 1.增加元素(采用尾插法) (1 ...

  5. 3.3 rust HashMap

    The type HashMap<K, V> stores a mapping of keys of type K to values of type V. It does this vi ...

  6. SpringMVC(2):JSON

    一,JSON 介绍 JSON (JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式.易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效 ...

  7. 【Linux】【Services】【SaaS】Docker+kubernetes(9. 安装consul实现服务注册发现)

    1. 简介 1.1. 官方网站: https://www.consul.io 1.2. Consul的功能: 服务发现:通过DNS或HTTP接口使得消费者发现服务,应用程序可以轻松找到所依赖的服务. ...

  8. 【Linux】【Shell】【text】grep

    grep: Global search REgular expression and Print out the line. 作用:文本搜索工具,根据用户指定的"模式(过滤条件)" ...

  9. Echarts 实现tooltip自动显示自动播放

    1.其实这个很容易实现,一个 dispatchAction 方法就解决问题:但是博主在未实现该功能时是花了大力气,各种百度,各种搜: 很难找到简单粗暴的例子,大多数随便回一句你的问题就没下文: 废话太 ...

  10. 什么是maven(一)

    转自博主--一杯凉茶 我记得在搞懂maven之前看了几次重复的maven的教学视频.不知道是自己悟性太低还是怎么滴,就是搞不清楚,现在弄清楚了,基本上入门了.写该篇博文,就是为了帮助那些和我一样对于m ...