我使用Tauri deep-link插件踩过的坑

最近在尝试使用Deep Linking | Tauri来实现应用登录,但是浏览器输入自定义url,却触发不了app。

这个插件非常的新,网络上几乎都搜不到什么资料,这里面的坑还是挺多的。

Dev模式下url无法触发的问题

首先,deep-link需要配合single instance插件来实现,否则每次打开url都会启动一个新的实例。

因此你需要先在项目中添加single instance插件Single Instance | Tauri,然后执行

bash 复制代码
yarn tauri build

构建出一个安装包,然后在你的电脑上安装之后,再使用yarn tauri dev就可以注册自定义url了。

但是之后又遇到了另外的问题,即使这样执行了之后,还是无法触发自定义url,在GitHub issues里也找到了类似的问题。

[bug] Register deep-link with single instance not working. · Issue #12726 · tauri-apps/tauri

后续首先尝试了在tauri.conf.json中添加schemes

json 复制代码
{
  "plugins": {
    "deep-link": {
      "mobile": [
        { "host": "your.website.com", "pathPrefix": ["/open"] },
        { "host": "another.site.br" }
      ],
      "desktop": {
        "schemes": ["something", "my-tauri-app"]
      }
    }
  }
}

然后在main函数中执行注册所有scheme,但是还是没法触发。

rust 复制代码
 use tauri_plugin_deep_link::DeepLinkExt;
  app.deep_link().register_all()?;

main函数初始化隐藏的坑

最后发现是main函数的锅,由于我们项目在main函数 tauri::Builder::default() 执行之前做了一些初始化的动作,single instance在初始化完成后才开始起效,所以相当于还是启动了两个实例。

解决方法:一定要把tauri::Builder::default()放到main函数的第一行执行,然后立刻注册single instance插件,否则single instance会出现问题。

最后我们的解决方案就是,把single instance放到main函数最前面,然后将项目的初始化放到了setup函数中,这样deep link就可以正常触发了。

rust 复制代码
fn main() {
    tauri::Builder::default()
        .plugin(tauri_plugin_single_instance::init(|app, argv, cwd| {
            println!("{}, {argv:?}, {cwd}", app.package_info().name);
        }))
        .plugin(tauri_plugin_updater::Builder::new().build())
        .plugin(tauri_plugin_os::init())
        .plugin(tauri_plugin_deep_link::init())
        .plugin(tauri_plugin_notification::init())
        .plugin(tauri_plugin_dialog::init())
        .plugin(tauri_plugin_shell::init())
        .plugin(tauri_plugin_process::init())
        .plugin(
            tauri_plugin_prevent_default::Builder::new()
                .with_flags(
                    Flags::FIND
                        | Flags::CARET_BROWSING
                        | Flags::OPEN
                        | Flags::PRINT
                        | Flags::DOWNLOADS,
                )
                .build(),
        )
        .setup(move |app| {
            if cfg!(debug_assertions) {
                use tauri_plugin_deep_link::DeepLinkExt;
                app.deep_link().register_all()?;
            }
        }
}

这样打包出来的app就可以正常注册url并且响应了。

相关推荐
咸甜适中1 小时前
rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(十四)垂直滚动条
笔记·学习·rust·egui
张志鹏PHP全栈5 小时前
Rust第四天,Rust中常见编程概念
后端·rust
咸甜适中8 小时前
rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(十五)网格布局
笔记·学习·rust·egui
susnm1 天前
最后的最后
rust·全栈
bruce541102 天前
深入理解 Rust Axum:两种依赖注入模式的实践与对比(二)
rust
该用户已不存在3 天前
这几款Rust工具,开发体验直线上升
前端·后端·rust
m0_480502645 天前
Rust 入门 生命周期-next2 (十九)
开发语言·后端·rust
寻月隐君5 天前
Rust Web 开发实战:使用 SQLx 连接 PostgreSQL 数据库
后端·rust·github
Moonbit6 天前
MoonBit Pearls Vol.05: 函数式里的依赖注入:Reader Monad
后端·rust·编程语言
Vallelonga6 天前
Rust 异步中的 Waker
经验分享·rust·异步·底层