如何通过外部链接唤起我们的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 可以获取到后面拼接的参数
});
相关推荐
萌面小侠Plus39 分钟前
Android笔记(三十三):封装设备性能级别判断工具——低端机还是高端机
android·性能优化·kotlin·工具类·低端机
慢慢成长的码农40 分钟前
Android Profiler 内存分析
android
大风起兮云飞扬丶40 分钟前
Android——多线程、线程通信、handler机制
android
L72561 小时前
Android的Handler
android
清风徐来辽1 小时前
Android HandlerThread 基础
android
HerayChen2 小时前
HbuildderX运行到手机或模拟器的Android App基座识别不到设备 mac
android·macos·智能手机
顾北川_野2 小时前
Android 手机设备的OEM-unlock解锁 和 adb push文件
android·java
hairenjing11232 小时前
在 Android 手机上从SD 卡恢复数据的 6 个有效应用程序
android·人工智能·windows·macos·智能手机
小黄人软件2 小时前
android浏览器源码 可输入地址或关键词搜索 android studio 2024 可开发可改地址
android·ide·android studio