如何通过外部链接唤起我们的Flutter app

Android通过deep link或者app link(本文使用deep link),iOS通过 url schema,可以打开对应的app,因此我们需要对我们的app进行对应的配置。

使用外部库:

主要用于监听用户的uri地址

yaml 复制代码
dependencies:
  # app links schema: 
  app_links: ^3.5.0

1. Android

1.1. 实现效果:

1.2. 配置

android/app/src/main/AndroidManifest.xml

xml 复制代码
<activity>
<!-- //... -->
  <intent-filter>
    <action android:name="android.intent.action.VIEW" />
    <category android:name="android.intent.category.DEFAULT" />
    <category android:name="android.intent.category.BROWSABLE" />
    <!-- 下面就是自己自定义的schema和host -->
   <data android:scheme="tradelink"
       android:host="hambit" />
  </intent-filter>
</activity>

1.3. 测试

浏览器输入网址:tradelink://hambit

如果需要携带参数直接拼接到地址后面也可以的:tradelink://hambit?param1=value1&param2=value2

1.4. 监听用户url打开浏览器

lib/main.dart

  • 在程序启动后进行监听,或者其他地方,看业务需求
dart 复制代码
import 'package:app_links/app_links.dart';

//...
final appLinks = AppLinks();
appLinks.allUriLinkStream.listen((uri) {
  print(uri); // 这里的uri就是你在浏览器输入的地址
  // 使用uri.queryParameters 可以获取到后面拼接的参数
});

2. iOS

2.1. 配置

  • 使用Xcode打开项目,新增一个 URL Type
  • 在项目中添加以下代码

ios/Runner/AppDelegate.swift

swift 复制代码
import UIKit
import Flutter
import FirebaseCore
import app_links  // 添加此行

@UIApplicationMain
@objc class AppDelegate: FlutterAppDelegate {
  override func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool {
    FirebaseApp.configure()
    GeneratedPluginRegistrant.register(with: self)
    // 添加以下行
    // ---
    if let url = AppLinks.shared.getLink(launchOptions: launchOptions) {
      AppLinks.shared.handleLink(url: url)
    }
    // ----
    return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  }
}

2.2. 测试

  • 浏览器输入:tradelink:// 或者 tradelink://hambit

  • 或者输入携带参数:tradelink://hambit?name="name"

2.3. 监听用户url打开浏览器

  • 用安卓设置的第4步一致
dart 复制代码
import 'package:app_links/app_links.dart';

//...
final appLinks = AppLinks();
appLinks.allUriLinkStream.listen((uri) {
  print(uri); // 这里的uri就是你在浏览器输入的地址
  // 使用uri.queryParameters 可以获取到后面拼接的参数
});
相关推荐
落落落sss2 小时前
MybatisPlus
android·java·开发语言·spring·tomcat·rabbitmq·mybatis
代码敲上天.3 小时前
数据库语句优化
android·数据库·adb
missmisslulu4 小时前
电容笔值得买吗?2024精选盘点推荐五大惊艳平替电容笔!
学习·ios·电脑·平板
GEEKVIP5 小时前
手机使用技巧:8 个 Android 锁屏移除工具 [解锁 Android]
android·macos·ios·智能手机·电脑·手机·iphone
GEEKVIP5 小时前
如何在 Windows 10 上恢复未保存/删除的 Word 文档
macos·ios·智能手机·电脑·word·笔记本电脑·iphone
奇客软件6 小时前
iPhone使用技巧:如何恢复变砖的 iPhone 或 iPad
数码相机·macos·ios·电脑·笔记本电脑·iphone·ipad
model20057 小时前
android + tflite 分类APP开发-2
android·分类·tflite
彭于晏6897 小时前
Android广播
android·java·开发语言
与衫8 小时前
掌握嵌套子查询:复杂 SQL 中 * 列的准确表列关系
android·javascript·sql
helloxmg9 小时前
鸿蒙harmonyos next flutter通信之MethodChannel获取设备信息
flutter