h5唤起App的原理

2020-07-15  本文已影响0人  RiverSouthMan

文章简述

唤起App的场景在前端开发中并不陌生。市面上有提供成熟的解决方案,Openinstall、应用宝、微信开放标签等...

image.png

目录

唤起场景

归纳一下我们唤起App的一些场景。针对不同场景,唤起App的解决方案也有不同。

  1. 手机浏览器唤起App
  2. 第三方App内webview唤起App。(微信、QQ、手百)

唤起方式

不同的唤起方式有各自的局限:唤起App方案

URL Scheme
广泛使用
APP需要注册自己的URL Scheme,用来唯一标识一个App
Scheme格式:<scheme域名>://<path>?<params>=<value>

Universal Links
iOS9+系统
唯一性
很好的兼容性
Universal Link是通过标准的http/https协议链接唤起App;若未安装App,访问此通用链接,可以自定义页面

URL Scheme

URL Schemes 是什么?通过对比网页链接来理解。

URL Schemes 有两个单词:

URL,我们都很清楚,http://www.apple.com 就是个 URL,我们也叫它链接或网址;
Schemes,表示的是一个 URL 中的一个位置——最初始的位置,即 ://之前的那段字符。比如 http://www.apple.com 这个网址的 Schemes 是 http。

根据我们上面对 URL Schemes 的使用,我们可以很轻易地理解,可以像定位一个网页一样,用一种特殊的 URL 来定位一个应用甚至应用里某个具体的功能。


image.png

安卓自定义Scheme
Android应用/组件间通信有一种方式是intent,应用可以注册intent filter声明自己对什么样的intent感兴趣,其它应用发送intent时通过系统级广播传递过来,如果与预先注册的intent filter匹配,应用将收到该intent(无论应用是否正在运行,都会被“唤醒”,也就是隐式启动Activity),取出intent携带的数据,做进一步处理。

就是这样,通过系统广播拿到一次起来的机会,例如在manifest里静态注册intent filter声明自定义scheme:

<activity android:name=".MainActivity">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />

        <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>

    <!--注册scheme-->
    <intent-filter>
        <action android:name="android.intent.action.VIEW"/>
        <category android:name="android.intent.category.DEFAULT"/>
        <!--BROWSABLE指定该Activity能被浏览器安全调用-->
        <category android:name="android.intent.category.BROWSABLE"/>
        <!--声明自定义scheme,类似于http, https-->
        <data android:scheme="hoho"/>
    </intent-filter>
</activity>

actioncategorydata都必须完全匹配才能获得intent,这里声明了2个category,只有在intent同时含有这2个category时才算匹配,而android.intent.category.DEFAULT是默认的,有实际意义的是android.intent.category.BROWSABLE,表示允许通过浏览器启动该activity(呼起App)。后续的data限定了触发条件,当scheme为hoho时才匹配,例如浏览器访问hoho://abc,能够匹配成功,App就起来了。

IOS自定义Scheme
在iOS 系统中,安装了一个app后,如果这个app有URL Scheme的话,安装完成后会在系统中注册该URL Scheme,这样别的app或者浏览器就可以通过URL Scheme来打开该app。

image.png

WebView Scheme白名单
WebView作为页面容器,可以过滤/拦截页面请求,以安卓为例:

class MyWebClient extends WebViewClient {

    @Override
    public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
        if (url.startsWith("hoho://")) {
            return null;
        }

        return super.shouldInterceptRequest(view, url);
    }

    @Override
    public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
        String scheme = request.getUrl().getScheme();
        if (scheme.equals("hoho")) {
            return null;
        }

        return super.shouldInterceptRequest(view, request);
    }
}

对于满足过滤条件的,拦截掉,所以在微信里无法呼起App,因为不在白名单里,被拦截下来,没有交给系统广播。现在微信提供了开放标签唤起App的能力。

Universal Link

官方文档

Universal Link(通用链接)是Apple在iOS9推出的一种能够方便的通过传统HTTPS链接来启动APP的功能,可以使用相同的网址打开网址和APP。当你的应用支持Universal Link(通用链接),当用户点击一个链接是可以跳转到你的网站并获得无缝重定向到对应的APP,且不需要通过Safari浏览器。如果你的应用不支持的话,则会在Safari中打开该链接。

实现通用链接不难, 但首先必须遵守一些先决条件。如下:

image.png

总结如图


image.png

参考文章

https://www.jianshu.com/p/136fd75ab05b
http://www.ayqy.net/blog/android-scheme%E5%91%BC%E8%B5%B7app/
https://www.jianshu.com/p/39a090338cd1
http://www.cocoachina.com/articles/13321
个人学习转载,若有冒犯请留言删除

上一篇 下一篇

猜你喜欢

热点阅读