Skip to main content

Command Palette

Search for a command to run...

Tauri v1 fs 访问任意文件的 bug

Published
1 min read
Tauri v1 fs 访问任意文件的 bug

在 Tauri 开发中,前端的 native 操作主要有两种实现方式:

  1. 一是直接通过 JS API,使用 Tauri 自己封装的那些方法

  2. 二是自己在 Rust 核心层进行开发,再通过 JS API 去 invoke 相关函数

第一种方式比较方便,但需要在 Tauri 配置文件中开放相关权限,作用域的和API 操作的(一方面是安全,另一方面可能是为了多平台运行考虑),比如:

{
  "tauri": {
    "allowlist": {
      "fs": {
        "scope": ["$APPDATA/databases/*"],
        "all": true, // enable all FS APIs
        "readFile": true,
        "writeFile": true,
        "readDir": true,
        "copyFile": true,
        "createDir": true,
        "removeDir": true,
        "removeFile": true,
        "renameFile": true,
        "exists": true
      }
    }
  }
}

如果你正在使用 fs 模块,要通过路径去访问本地文件,那么你有三种方法去获取该文件的访问权限:

  1. 把文件路径写在 scope 中,这里只能写死,编译时就确定了,不能动态调整

  2. 通过 dialog 模块弹窗,让用户先选择文件路径,此后该文件路径就会进入访问白名单

  3. 选择在 Rust 核心层开发文件读写,跳过 fs 模块

关于 scope 的范围,文档是这么说的:

This module prevents path traversal, not allowing absolute paths or parent dir components (i.e. "/usr/path/to/file" or "../path/to/file" paths are not allowed). Paths accessed with this API must be relative to one of the base directories so if you need access to arbitrary filesystem paths, you must write such logic on the core layer instead.

大意是不能使用绝对路径,也不能通过 .. 访问父目录,要访问任意文件你就自己写 Rust 去弄。

但经我测试,他的 scope 范围有 bug,如果你把 scope 写满通配符,那么他的检查就失效了:

{
  "tauri": {
    "allowlist": {
      "fs": {
        "scope": ["**", "**/*", "/**/*", "*/**"],
        "all": true
      }
    }
  }
}

现在你就可以通过 JS API 访问去访问任意文件了,无需提前使用 dialog 弹窗选择文件。

More from this blog

12 月装机行动记录

(Banner 图文无关) 这几天买了新的装备回来升级配置,除了显卡和散热器,其他都更新了,这两个不更新的原因是太贵了。 由于我不太懂选配置,所以还是让朋友给推荐,我说我的预算在 5000 左右,他就给我转了一个整机,配置大概是这样的: CPU:AMD 9700X 主板:微星 B650M GAMING PLUS WIFI 或者 微星 B650M GAMING WIFI 显卡:木有 内存:英睿达/宇瞻 DDR5 6000 32G 硬盘:1T NVMe PCIe4 SSD 读速 3500M...

Dec 7, 20241 min read
12 月装机行动记录

Homekit + cozylife 插座连接 HA

近期在淘宝上买了个 Homekit + cozylife 的插座,就这种: 一开始只通过 iOS 访问,就是只连接 Homekit,长按开关重置插座,iOS 一扫码就连上了,后来我嫌在外面访问不了,又不想掏钱买苹果的 HomePod,于是就装上了 Home Assistant,打算让设备们都连上 HA,这样就不用交苹果税了。 连接方式还是通过 Homekit,一般来说支持 Homekit 设备都能这样连接,先连上 iOS,然后在 Home App 中移除设备,这时候就能在 HA 中找到设备了:...

Nov 30, 20241 min read
Homekit + cozylife 插座连接 HA

找到了一台祖传的 Ccd 相机

开个玩笑,这台相机其实是我们家在 05 年的时候买的,发票都还在呢,当时花了 4000 块钱!搁现在我都受不了,更别说当年了,看到价格我都震惊了。 相机的型号是索尼的 Cybershot DSC-N1,属于小红书时尚单品 CCD 相机,由于一直放在包装盒里,现在还有 99 新呢。 机子还是正常的,能开机,能拍照,其中一个问题是日期,这款没有 WiFi 功能,所以时间只能保存在本地,不知道是不是 BUG,每次开机都让我重新设置,默认就定在 2005 年 1 月 1 日。 第二个问题是电池,电池应该...

Nov 28, 20241 min read
找到了一台祖传的 Ccd 相机

记录和 ffmpeg 与 LLM 搏斗的两天

要做的 最近在写一个制作视频的功能,就是把 N 个视频合并,然后把对应的 N 张图片,在视频开始的前 5 秒叠加显示出来。 第一口 - diffusion studio 本来我用的是 diffusion studio,这是一个 JS 库,但这玩意性能太差了,因为他要把视频每一帧都读到 canvas 里,数据一多页面就卡住了(为啥要折腾 DOM 呢?) 而且他的 API 十分不好用,作为浏览器脚本你无法读本地数据也就算了,你起码给一个接受纯数据的参数吧,比如 HTML 类型接受源代码,Image ...

Nov 16, 20242 min read
记录和 ffmpeg 与 LLM 搏斗的两天
V

void mian

39 posts