Bootstrap

Tauri 官方FS文档接口和尝试踩坑

这里先写上tauri官方fs的文档链接fs | Tauri Apps

这里说下我踩的坑,

在使用tauri fs之前,你需要确保在“tauri.conf.json”文件中允许列表中启用了fs:

在tauri.conf.json里面的tauri里面allowlist里添加下面代码,(scope是允许访问的的路径,我这里允许他访问APPDATA里的所有文件)


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

前端的话说就是用到什么接口就引入什么如下(这里只显示部分接口,想看其他可以去官方文档查看)

import {
  appDataDir,
} from "@tauri-apps/api/path";

import {
  writeTextFile,
} from "@tauri-apps/api/fs";

前端注意路径的拼写,比如我要写一个1.txt文件放到$APPDATA里的test目录里面

一般来说我们可能会这样像下面这样写(下面这个是错误的写法)

writeTextFile("test"+ "\1.txt","这是1.txt的内容",{ dir: BaseDirectory.AppData }
).then((res) => {
    //控制台查看打印结果
    console.log(res);
});

下面是正确写法,因为我看文档里面的是2个\\来拼接,但是前端是\\才算一个\所以下面代码用到了4个\

writeTextFile("test"+ "\\\\1.txt","这是1.txt的内容",{ dir: BaseDirectory.AppData }
).then((res) => {
    //控制台查看打印结果
    console.log(res);
});

这里说下BaseDirectory.AppData在本地的路径是C:\Users\admin\AppData\Roaming
然后tauri.conf.json里面的bundle里面的identifier的值是数据目录名,比如我的是com.tauri.build
那么我写入上面的文件之后,那么这个文件目录路径是C:\Users\admin\AppData\Roaming\com.tauri.com\test\1.txt

test是我手动创建的目录,也可以通过代码创建test目录。

下面是官方接口例子

copyFile----复制文件

import { copyFile, BaseDirectory } from '@tauri-apps/api/fs';
// Copy the `$APPCONFIG/app.conf` file to `$APPCONFIG/app.conf.bk`
await copyFile('app.conf', 'app.conf.bk', { dir: BaseDirectory.AppConfig });

createDir----创建目录

import { createDir, BaseDirectory } from '@tauri-apps/api/fs';
// Create the `$APPDATA/users` directory
await createDir('users', { dir: BaseDirectory.AppData, recursive: true });

exists----文件是否已存在

import { exists, BaseDirectory } from '@tauri-apps/api/fs';
// Check if the `$APPDATA/avatar.png` file exists
await exists('avatar.png', { dir: BaseDirectory.AppData });

readBinaryFile----读取二进制文件

import { readBinaryFile, BaseDirectory } from '@tauri-apps/api/fs';
// Read the image file in the `$RESOURCEDIR/avatar.png` path
const contents = await readBinaryFile('avatar.png', { dir: BaseDirectory.Resource });

readDir---查看目录列表

import { readDir, BaseDirectory } from '@tauri-apps/api/fs';
// Reads the `$APPDATA/users` directory recursively
const entries = await readDir('users', { dir: BaseDirectory.AppData, recursive: true });

function processEntries(entries) {
  for (const entry of entries) {
    console.log(`Entry: ${entry.path}`);
    if (entry.children) {
      processEntries(entry.children)
    }
  }
}

readTextFile----读取文件

import { readTextFile, BaseDirectory } from '@tauri-apps/api/fs';
// Read the text file in the `$APPCONFIG/app.conf` path
const contents = await readTextFile('app.conf', { dir: BaseDirectory.AppConfig });

removeDir----删除目录

import { removeDir, BaseDirectory } from '@tauri-apps/api/fs';
// Remove the directory `$APPDATA/users`
await removeDir('users', { dir: BaseDirectory.AppData });

removeFile----删除文件
 

import { removeFile, BaseDirectory } from '@tauri-apps/api/fs';
// Remove the `$APPConfig/app.conf` file
await removeFile('app.conf', { dir: BaseDirectory.AppConfig });

renameFile----重命名文件

import { renameFile, BaseDirectory } from '@tauri-apps/api/fs';
// Rename the `$APPDATA/avatar.png` file
await renameFile('avatar.png', 'deleted.png', { dir: BaseDirectory.AppData });

writeBinaryFile----写入二进制文件

import { writeBinaryFile, BaseDirectory } from '@tauri-apps/api/fs';
// Write a binary file to the `$APPDATA/avatar.png` path
await writeBinaryFile('avatar.png', new Uint8Array([]), { dir: BaseDirectory.AppData });

writeTextFile----写入文本文件
 

import { writeTextFile, BaseDirectory } from '@tauri-apps/api/fs';
// Write a text file to the `$APPCONFIG/app.conf` path
await writeTextFile('app.conf', 'file contents', { dir: BaseDirectory.AppConfig });

;