uniapp+vue开发app,蓝牙连接,蓝牙接收文件保存到手机特定文件夹,从手机特定目录(可自定义),读取文件内容,这篇首先说如何读取,手机目录如何寻找

首先说一下研究思路,时间紧急不看的直接拿取粉色代码部分即可

1.首先要解决第一个问题就是手机目录是什么,文件路径如何写,参考了一篇文章中的这一句话

标蓝


//Android平台本地绝对路径为"storage/emulated/0",就是用户文件管理器能看到的了;

filename: 'file://storage/emulated/0/xxx/'


所以尝试了以下方法

// plus.io.resolveLocalFileSystemURL(url,function(entry){

// console.log("entry",entry)

// entry.file(function(file){

// var reader=new plus.io.FileReader()

// reader.onloadend=function(e){

// console.log('filecontent',e.target.result)

// }

// reader.readAsText(file,'utf-8')

// })

// })

发现,不行,后得知, 这种方式手机版本10+就不行了

现在是需要将路径的file://去掉,根目录就是/storage/,到0为手机文件管理可以看到的路径了,以下为微信下载的文件举例

const filePath = '/storage/emulated/0/Download/WeiXin/shuju.dat';

// 替换为你的实际文件路径
this.ceshidata= readFileContent(filePath);

安卓10+以下系统获取文件目录

通过5+ 提供的api获取文件目录 plus.io.resolveLocalFileSystemURL

安卓10+以上系统获取文件目录

通过引入安卓原生类 File 获取文件列表及文件

// 导入 java.io.File 类 var File = plus.android.importClass('java.io.File');

// 创建 File 对象,指定目录路径 var dir = new File(dirPath);

// 获取目录下的文件列表 var files = dir.listFiles();

2.完整的读取代码

	function readFileContent(filePath) {
				try {
					// 导入必要的类
					var File = plus.android.importClass('java.io.File');
					var FileInputStream = plus.android.importClass('java.io.FileInputStream');
					var InputStreamReader = plus.android.importClass('java.io.InputStreamReader');
					var BufferedReader = plus.android.importClass('java.io.BufferedReader');

					// 创建File对象
					var file = new File(filePath);
					// 输出更多调试信息
					console.log('Attempting to read file at path: ' + filePath);
					console.log('File exists: ' + file.exists());
					console.log('Is file: ' + file.isFile());
					console.log('Absolute path: ' + file.getAbsolutePath());
					if (file.exists() && file.isFile()) {
						// 打开文件输入流
						var fis = new FileInputStream(file);
						var isr = new InputStreamReader(fis, "UTF-8"); // 指定编码格式
						var br = new BufferedReader(isr);

						var content = '';
						var line;
						while ((line = br.readLine()) !== null) {
							content += line + '\n';
						}

						// 关闭资源
						br.close();
						isr.close();
						fis.close();

						// 输出文件内容到控制台或做其他处理
						console.log('File: ' + file.getName() + ', Content: ' + content);
						
						return content; // 或者你可以选择返回文件内容
					} else {
						console.log('The specified file does not exist or is not a regular file.');
					}
				} catch (e) {
					console.error('Error reading file: ' + e.message);
				}
			}
相关推荐
黑客老陈几秒前
新手小白如何挖掘cnvd通用漏洞之存储xss漏洞(利用xss钓鱼)
运维·服务器·前端·网络·安全·web3·xss
正小安6 分钟前
Vite系列课程 | 11. Vite 配置文件中 CSS 配置(Modules 模块化篇)
前端·vite
向宇it9 分钟前
【从零开始入门unity游戏开发之——unity篇01】unity6基础入门开篇——游戏引擎是什么、主流的游戏引擎、为什么选择Unity
开发语言·unity·c#·游戏引擎
编程百晓君26 分钟前
一文解释清楚OpenHarmony面向全场景的分布式操作系统
vue.js
是娜个二叉树!26 分钟前
图像处理基础 | 格式转换.rgb转.jpg 灰度图 python
开发语言·python
Schwertlilien30 分钟前
图像处理-Ch5-图像复原与重建
c语言·开发语言·机器学习
liuyunshengsir33 分钟前
Squid代理服务器的安装使用
开发语言·php
暴富的Tdy33 分钟前
【CryptoJS库AES加密】
前端·javascript·vue.js
neeef_se34 分钟前
Vue中使用a标签下载静态资源文件(比如excel、pdf等),纯前端操作
前端·vue.js·excel
m0_7482356140 分钟前
web 渗透学习指南——初学者防入狱篇
前端