美文网首页Swift进阶首页投稿(暂停使用,暂停投稿)iOS Developer
快速打通通用链接 解决在微博,微信等内置浏览器无法跳转app的问

快速打通通用链接 解决在微博,微信等内置浏览器无法跳转app的问

作者: 字母B一路向北 | 来源:发表于2017-06-23 11:52 被阅读425次

    现在有这样一个需求:用户点击分享文章上的"打开app"跳转到我们的App中或者App中的指定页面。

    IMG_0069.PNG

    可行的方案大概有三种:

    一、直接使用URL Scheme。

    (优点:十分简单,在plist文件中配置一个scheme,点击短信中的scheme或者将scheme输入到浏览器中就可以直接跳到App中。 缺点:当手机上没有安装App时,短信中点击scheme会没有反应,浏览器中会访问失败。而且在微信和QQ中这种方式是被禁用的)。因为有些app的内置浏览器是不让你随便跳到别人的app的,除非你和人家有合作,人家单独给你开通VIP通道,哈哈!

    Snip20170623_1.png
    把URL Schemes交给做web的同学,进行配置,记住 后面要加 :// 例如: nodellink://

    二、使用iOS9之后的新特性,通用链接(Universal Links)。

    这是我做过的,下面把流程走一遍:
    1.先决条件:你必须有一个域名,且这个域名需要支持https。
    这个去找你们的后台要
    2.去开发者中心
    对应的appid下申请一下权限


    Snip20170623_2.png

    3.打开工程配置中的Associated Domains,在其中的Domains中填入你想支持的域名,必须以applinks:为前缀。


    Snip20170623_2.png

    4.创建一个内容为json格式的文件,苹果将会在合适的时候,从我们在项目中填入的域名请求这个文件。这个文件名必须为apple-app-site-association,没有后缀名,文件内容是这样子的:

     {
        "applinks": {
            "apps": [],
            "details": [
                {
                    "appID": "9JA89QQQQQ.com.apple.wwdc",
                    "paths": [ "/wwdc/news/", "/videos/wwdc/2015/*"]
                },
                {
                    "appID": "ABCD1234.com.apple.wwdc",
                    "paths": [ "*" ]
                }
            ]
        }
    }
    

    我们后台的做法是直接出去了一个字典,链接最后不要带有路径域名直接加apple-app-site-association,且不要带json后缀

     {
        "applinks": {
            "apps": [],
            "details": [
                {
                    "appID": "ABCD1234.com.apple.wwdc",
                    "paths": [ "*" ]
                }
            ]
        }
    }
    

    说明:
    appID:组成方式是 teamId.yourapp’s bundle identifier。如上面的 9JA89QQQQQ就是teamId。登陆开发者中心,在Account - Membership里面可以找到Team ID。

    paths:设定你的app支持的路径列表,只有这些指定的路径的链接,才能被app所处理。星号的写法代表了可识别域名下所有链接。

    5.上传该文件到你的域名所对应的根目录或者.well-known目录下,这是为了苹果能获取到你上传的文件。上传完后,自己先访问一下,看看是否能够获取到,当你在浏览器中输入这个文件链接后,应该是直接下载apple-app-site-association文件。
    (不过我们并没有上传到更目录,而且苹果官方校验并未通过,然并软,我们在记事本上实验通过)
    千万不要认为坑踩完了,还有一个很隐蔽的,本人读了三遍苹果英文文档,文档中都没有写,就是你分享的链接的域名和你点开链接里的打开按钮web所替换的链接的域名一定不能相同,我被这个问题坑了一个月,怎么都调不起来应用。估计是微信和qq内部做了屏蔽,只有这两个链接域名不一样的时候才能调起应用

    6.把这个域名给到你们的web人员手中,可以让他在跳转的按钮功能进行配置,以及加入相关参数,我们可以在delegate中解析(但是需要注意的是这时链接后面就不需要添加://了)

     func application(_ application: UIApplication, continue userActivity: NSUserActivity,
                         restorationHandler: @escaping ([Any]?) -> Void) -> Bool {
            //判断是从Universal Links进来的链接
            if userActivity.activityType == NSUserActivityTypeBrowsingWeb {
                let webpageURL = userActivity.webpageURL
    //            print("点击的链接是:\(webpageURL)")
                //进行后续的处理,根据参数进行相关跳转,(参数你们自己定)
            }
            return true
        }
    
    ![IMG_0069.PNG](https://img.haomeiwen.com/i1662323/cecd82f69008ebec.PNG?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240))
    

    三、让后台人员写一个可以访问的网页,点击短信中的链接,跳转到网页

    在网页中判断是iOS端还是安卓端,然后自动跳转对应的scheme,如果手机上安装了App,则直接跳到App,如果没有安装App,则停留在当前网页,在网页上有一个去下载的按钮,点击按钮可以去下载App。
    如果需要跳到指定页面,需要在发送短信时让后台人员将参数拼接在链接后边,之后拼接到scheme后面带到App中,然后我们在AppDelegate的-(BOOL)application: openURL和-(BOOL)application: openURL: options:的方法里接收传入进来的url链接后面的参数,之后进行指定页面的跳转就可以了。\

    [相关链接]
    http://blog.csdn.net/kuangdacaikuang/article/details/52955070
    https://yohunl.com/ios-universal-links-tong-yong-lian-jie/
    http://blog.csdn.net/mo_xiao_mo/article/details/60954116
    http://www.jianshu.com/p/738ac2b8865d
    http://www.jianshu.com/p/ddf6c0b5f0fd
    http://blog.csdn.net/nvlangxin/article/details/50896524

    相关文章

      网友评论

      • 龙牙牙:请问是否了解,微博是否有做内置跳转其他app白名单的限制,相同的跳转方式在qq可以实现但微博实现不了,看到文章中说的白名单,请问您知道如何求证么?
        字母B一路向北:微博没有限制呀,微信倒是有限制了,貌似
      • 闻说双溪春尚好_:请问这个Domains中填写的域名具体是什么
        字母B一路向北:这个看你们服务端给你能提供什么样的域名啦

      本文标题:快速打通通用链接 解决在微博,微信等内置浏览器无法跳转app的问

      本文链接:https://www.haomeiwen.com/subject/yjxccxtx.html