首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Capacitor API -无法使用Filesystem.writeFile在设备上写入文件

Capacitor API -无法使用Filesystem.writeFile在设备上写入文件
EN

Stack Overflow用户
提问于 2020-07-06 12:57:47
回答 4查看 6.9K关注 0票数 0

我正在开发一个使用Angular 9/ Ionic 5/ Capacitor 2.0的混合应用程序。我正在尝试将来自API的文件(基本上是PDF或图像文件)作为Blob保存到我的移动设备(IOS/Android)的文件系统中。我的最终目标是重现文件的类似浏览器的下载功能(允许用户将其保存在手机上)。

下面是我的代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  downloadNativeFile(blob: Blob, fileName: string){
    let reader = this.getFileReader();
    reader.onloadend = (readerEvent) => {
      if(reader.error){
        console.log(reader.error);
      } else {
        let base64data: any = readerEvent.target['result'];
        try {
          Filesystem.writeFile({
            path: fileName,
            data: base64data,
            directory: FilesystemDirectory.Data
          }).then((res)=>{
            Filesystem.getUri({
              directory: FilesystemDirectory.Data,
              path: fileName
            }).then((getUriResult) => {
              const path = getUriResult.uri;
              console.log("The file's path : " + path);
              console.log(Capacitor.convertFileSrc(getUriResult.uri));              
            }, (error) => {
              console.log(error);
            });
          }).catch((err)=>{
            console.log("Error", err);
          });
        } catch(e) {
          console.error('Unable to write file', e);
        }
      }
    }

    reader.readAsDataURL(blob);
  }

执行这段代码,我没有得到任何错误,并且我的控制台打印保存的文件的路径:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
The file's path : /DATA/sample.pdf
http://localhost/_capacitor_file_/DATA/sample.pdf

不过,我在设备上找不到任何新文件(我还尝试了FilesystemDirectory枚举中的所有值)。在Android (7 & 10)和IOS (13)上进行了测试。

我的Blob很好(我可以在浏览器中可视化它),并且dataUrl转换已经正确完成。

因此,来自Capacitor FileSystem API的writeFile函数似乎无法将文件保存到设备上。

有人知道这是为什么吗?我该如何解决这个问题?我真的被困住了,目前还不能实现这个功能。

下面是我的依赖项和插件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  "dependencies": {
    "@angular/animations": "^9.1.7",
    "@angular/cdk": "^9.2.3",
    "@angular/common": "^9.1.7",
    "@angular/compiler": "^9.1.7",
    "@angular/core": "^9.1.7",
    "@angular/fire": "^5.4.2",
    "@angular/forms": "^9.1.7",
    "@angular/material": "^9.2.3",
    "@angular/material-moment-adapter": "^9.2.4",
    "@angular/platform-browser": "^9.1.7",
    "@angular/platform-browser-dynamic": "^9.1.7",
    "@angular/platform-server": "^9.1.7",
    "@angular/router": "^9.1.7",
    "@angular/service-worker": "^9.1.7",
    "@auth0/angular-jwt": "^2.1.0",
    "@capacitor/android": "^2.1.0",
    "@capacitor/core": "2.1.0",
    "@capacitor/ios": "^2.1.0",
    "@ionic-native/core": "^5.25.0",
    "@ionic-native/fcm": "^5.26.0",
    "@ionic-native/http": "^5.26.0",
    "@ionic-native/splash-screen": "^5.25.0",
    "@ionic-native/status-bar": "^5.25.0",
    "@ionic/angular": "^5.1.1",
    "@ngrx/effects": "^9.1.2",
    "@ngrx/entity": "^9.1.2",
    "@ngrx/store": "^9.1.2",
    "@ngrx/store-devtools": "^9.1.2",
    "ajv": "^6.9.1",
    "angular2-text-mask": "^9.0.0",
    "animate.css": "^3.7.0",
    "bootstrap-sass": "^3.4.0",
    "capacitor-fcm": "^2.0.0",
    "classlist.js": "^1.1.20150312",
    "cordova-plugin-advanced-http": "^2.4.1",
    "cordova-plugin-file": "^6.0.2",
    "core-js": "^2.6.4",
    "fibers": "^4.0.3",
    "file-saver": "^2.0.2",
    "firebase": "^5.8.2",
    "font-awesome": "^4.7.0",
    "html-webpack-plugin": "^2.21.0",
    "jetifier": "^1.6.6",
    "lottie-web": "^5.4.3",
    "moment": "^2.24.0",
    "ngx-markdown": "^9.0.0",
    "pwa": "^1.9.6",
    "rxjs": "^6.5.5",
    "scrolling-element": "^1.0.2",
    "tslib": "^1.10.0",
    "web-animations-js": "^2.3.2",
    "zone.js": "~0.10.2"
  },
  "devDependencies": {/**/},
  "cordova": {
    "plugins": {
      "cordova-plugin-advanced-http": {}
    }
  }
EN

回答 4

Stack Overflow用户

发布于 2020-08-28 12:48:33

console.log方法的输出实际上可以给出文件系统错误导入的提示。

而不是:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import { Filesystem } from '@capacitor/core';

尝试:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const { Filesystem } = Plugins;
票数 5
EN

Stack Overflow用户

发布于 2020-07-06 13:35:23

文件系统访问很棘手,因为每个系统(安卓、iOS等)都有自己的own rules

Android允许你描述的行为,但是你需要使用FilesystemDirectory.Documents而不是FilesystemDirectory.Data作为目录来写入文件。点击此处查看更多信息:https://capacitorjs.com/docs/apis/filesystem (滚动到FilesystemDirectory枚举)

iOS不允许直接访问文件,您可以尝试使用icloud文件夹路由来实现您想要的内容。请看这个答案:Save file to public directory using Cordova FileTransfer

但由于你的用例是允许类似“下载”的行为--试着看看这个库是否能为你做这个:https://github.com/eligrey/FileSaver.js/它是web而不是原生API,但在现代浏览器中工作得很好。

票数 0
EN

Stack Overflow用户

发布于 2020-11-04 15:48:07

你好,先生,我有同样的问题,先生,我想在我的代码中实现这一点。先生,我能看一下这个的完整代码吗?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let reader = this.getFileReader();
reader.onloadend = readerEvent => {
  if (reader.error) {
     console.error(reader.error);
  } else {
     let base64data: any = readerEvent.target['result'];
     let mimeType = base64data.substring(base64data.indexOf(":")+1, base64data.indexOf(";"));
     let options: IWriteOptions = { replace: true };
     this.file.writeFile(this.file.dataDirectory, fileName, blob, options).then(res => {
        this.fileOpener.open(this.file.dataDirectory + fileName, mimeType);
     });
  }
};
reader.readAsDataURL(res.body);

特别是这一个let reader = this.getFileReader();和您使用的导入包,谢谢

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62756611

复制
相关文章
Makefile文件
title: Makefile文件 文章目录 title: Makefile文件 Makefile文件 Makefile文件 make命令执行时,需要一个makefile文件,以告诉make命令需要怎么样的去编译和链接程序。 image.png image.png image.png image.png
AI拉呱
2021/01/14
6080
输出cglib以及jdk动态代理产生的class文件
好奇心重的小伙伴有一种知其然,亦欲知其所以然的特性,我们在spring事务应用中会接触到aop技术,而aop背后隐藏的恰恰是以jdk以及cglib为基础的动态代理技术,博主不才,将自己的学习历程记录于此,希望帮到有需求的同行,其实我们仅需要进行简单的设置,即可输出cglib以及jdk动态代理产生的class文件,然后使用jdt或者其他工具查看生成的动态代理类,以验证理论知识:
johnhuster的分享
2022/03/29
5420
Makefile文件编写
make 的参数有很多, 可以通过 make -h 去查看, 下面只介绍几个我认为比较有用的。
用户2929716
2018/08/23
1.2K0
Makefile 文件格式;makefile伪目标
           第二行的gcc -o test prog.o code.o是可运行命令。
西湖醋鱼
2020/12/30
8290
多文件目录Makefile的写法
  linux下程序开发,涉及到多个文件,多个目录,这时候编译文件的任务量比较大,需要写Makefile
杨永贞
2020/08/04
4K0
多文件目录Makefile的写法
EditPlus如何设置保存时不产生.bak备份文件?
大家在使用EditPlus时都会遇到这么一个问题,就是每次保存或者修改后保存时都会生成一个.bak后缀的文件,这个是一个缓存文件。那如何才能不生成该缓存文件呢?操作如下图所示:
黑泽君
2018/10/11
1.5K0
makefile 指定文件的生成目录[通俗易懂]
1.上一篇博客虽然简单实现了自动处理依赖关系,但是生成的各种临时文件都混在一起,太乱了。
全栈程序员站长
2022/09/01
4.3K0
makefile文件编写「建议收藏」
makefile文件用于管理和组织代码工程的编译和链接,其不是可执行文件,其被make工具解析并完成相关动作,下面笔者将介绍makefile中常用的一些语法说明:
全栈程序员站长
2022/09/06
3.3K0
makefile文件编写「建议收藏」
【Makefile】简单的Makefile编写
Makefile编写 程序的编译和链接 使用C、C++编写可执行文件,首先要把源文件编译成中间代码文件,Linux下是.o文件,即Object File,这个动作叫做编译(complie)。 然后再把大量的Object File合成执行文件,这个动作叫链接(link)。 一个项目会拥有成百上千个源程序文件,再使用G++ or GCC会很麻烦。于是Makefile闪亮登场。 Makefile确定整个工程的编译规则,只需要一个make命令,就可以实现“自动化编译”。 make是一个解释Make
半生瓜的blog
2023/05/13
1K0
【Makefile】简单的Makefile编写
make命令和makefile文件
  make命令和makefile文件的结合提供了一个在项目管理领域十分强大的工具,它不仅常被用于控制源代码的编译,而且还用于手册页的编写以及将应用程序安装到目标目录。
全栈程序员站长
2022/07/18
2.6K0
浅谈内核的Makefile、Kconfig和.config文件
Linux内核源码文件繁多,搞不清Makefile、Kconfig、.config间的关系,不了解内核编译体系,编译修改内核有问题无从下手,自己写的驱动不知道怎么编进内核,不知道怎么配置内核,这些问题都和Makefile、Kconfig、.config有关,下面简单谈谈Makefile、Kconfig和.config。希望对你有启发。
韦东山
2020/09/30
3.8K0
浅谈内核的Makefile、Kconfig和.config文件
Scrapy之日志文件的产生
我们写爬虫的时候,也许会需要记录一些数据或者异常信息,通常这些数据我们会希望以日志的形式保存下来。
钱塘小甲子
2019/01/29
9120
一个Makefile 文件实例模板
1  在Linux下,一般使用GCC文件,比较头疼的问题,每次编写Makefile文件,比较麻烦,关键是经常忘记makefile语法;
无限之生
2020/06/30
7240
5个编写高效Makefile文件的最佳实践
在编写Makefile文件之前,我们需要明确我们的目标是什么。我们需要知道我们需要构建哪些文件,以及它们之间的依赖关系。为了确定目标,我们需要考虑以下问题:
小万哥
2023/05/20
3040
5个编写高效Makefile文件的最佳实践
设置打印输出不缓冲
❝通过设置setvbuf函数达到打印输出不缓冲的功能,以消除输出延时。❞ 原型 int setvbuf(FILE *stream, char *buffer, int mode, size_t size); 「stream」:将缓冲区设置为文件流。 「buffer」:指向流使用的缓冲区的指针,或指向仅更改大小和模式的空指针。 「mode」:缓冲模式使用。它有以下值之一: _IOFBF 全缓冲 _IOLBF 行缓冲 _IONBF 没有缓冲 「size」:缓冲区大小。 返回为0即成功,否则失败。 使用   
Qt君
2020/04/17
2.2K0
为sourceinsight添加makefile和configure文件
在用sourceinsight查看ffmpeg源码的时候,大家会发现不能查看源码中的makefile代码,即不能搜索到makefile文件。这是因为source insight默认是不选makefile的,也没有configure这种类型的文件。下面就说如何让sourceinsight支持查看makefile和configure代码:
雪影
2018/08/02
1.1K0
年薪百万的机器学习专家,为什么不产生价值?
本文转载自第四范式知乎专栏,量子位已获得授权。 「范式大学系列课程」第 3 篇文章: 年薪百万的机器学习专家,为什么不产生价值? Part 1 一个朋友的企业,他们招聘了 2 名机器学习方向的数据科学
量子位
2018/03/30
6470
年薪百万的机器学习专家,为什么不产生价值?
点击加载更多

相似问题

简单的makefile不产生输出文件(正确)

11

解析不产生预期输出

13

函数不产生预期输出

13

DFS方法不产生预期输出

10

Java - cast不产生预期的输出

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文