如何通过外部链接唤起我们的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 可以获取到后面拼接的参数
});
相关推荐
雨白2 小时前
Jetpack系列(二):Lifecycle与LiveData结合,打造响应式UI
android·android jetpack
kk爱闹4 小时前
【挑战14天学完python和pytorch】- day01
android·pytorch·python
每次的天空5 小时前
Android-自定义View的实战学习总结
android·学习·kotlin·音视频
恋猫de小郭6 小时前
Flutter Widget Preview 功能已合并到 master,提前在体验毛坯的预览支持
android·flutter·ios
断剑重铸之日7 小时前
Android自定义相机开发(类似OCR扫描相机)
android
随心最为安7 小时前
Android Library Maven 发布完整流程指南
android
岁月玲珑7 小时前
【使用Android Studio调试手机app时候手机老掉线问题】
android·ide·android studio
还鮟11 小时前
CTF Web的数组巧用
android
点金石游戏出海12 小时前
每周资讯 | Krafton斥资750亿日元收购日本动画公司ADK;《崩坏:星穹铁道》新版本首日登顶iOS畅销榜
游戏·ios·业界资讯·apple·崩坏星穹铁道
小蜜蜂嗡嗡12 小时前
Android Studio flutter项目运行、打包时间太长
android·flutter·android studio