html - appLinks 不会从电子邮件中打开 iPhone 应用程序

标签 html ios iphone facebook applinks

我正在尝试创建一个环境来支持从电子邮件中打开 iPhone 应用程序。如果我将 Facebook 的托管服务用于 appLink ( Facebook AppLink Hosting API ),只要单击它从 Facebook 移动应用程序中生成的链接,我就可以成功打开该应用程序。但是,如果我尝试从另一个移动应用程序(例如 Notes 或 Mail)中单击相同的链接,它只会重定向到 Facebook,而不是我的应用程序。此外,Facebook AppLink Hosting API 仅允许您为单个应用程序创建链接。我希望能够根据用户在其移动设备上安装的应用自动打开付费版本的应用或应用的免费版本(按此顺序)。

因此,我按照在 ( applinks.org ) 中找到的关于如何在我自己的服务器上设置元标记来执行打开 AppLink 的任务的描述进行操作。所以,我有一个包含以下 html 的网页:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>MyApp</title>
<meta property="al:iphone:url" content="myAppLinkScheme://Home">
<meta property="al:iphone:app_name" content="MyApp">
<meta property="al:iphone:app_store_id" content="471147787">
<meta property="al:iphone:url" content="myAppLinkLiteScheme://Home">
<meta property="al:iphone:app_name" content="MyApp Lite">
<meta property="al:iphone:app_store_id" content="518829102">
<meta property="al:ipad:url" content="myAppLinkLiteScheme://Home">
<meta property="al:ipad:app_name" content="MyApp Lite">
<meta property="al:ipad:app_store_id" content="518829102">
<meta property="al:web:should_fallback" content="false">
</head>
<body>Redirecting...</body>
</html>

然后我使用 Facebook 的托管 AppLink 的工具创建了一个 appLink。使用他们的 Open Graph Object Debugger ,我能够抓取我用他们的工具创建的 AppLink 的内容。 Facebook 元标记与我的元标记非常相似,但有一些不同之处。正如我之前提到的,第一个区别是您只能使用 Facebook 工具指定一个应用程序,因此只有一个 iPhone url、app_name 和 app_store_id 元标记。另外两个区别是以下标签 [我将以下标签中的 app_id 替换为 ....]:

<meta property="fb:app_id" content="28...........64">
<meta http-equiv="refresh" content="0;url=https://apps.facebook.com/28...........64/?fb_source=mobile">

很明显,“刷新”元标记会重定向到 apps.facebook.com。我不知道那里发生了什么,但即使我将所有这些标签都放在我的网页标题标签中,结果也是一样的。如果您从 Mail 或 Notes 等移动应用程序中单击链接,您将只会打开我的网页。我的应用程序或 Facebook 不会发生重定向。

请注意,我还向我的每个应用程序的 info.plists 和 appDelegates 添加了所需的方案信息。即,在我的 info.plist 的 URL 类型中,我添加了 com.myApp.myAppLinkScheme 的标识符和 myAppLinkScheme 的方案。对 info.plist 的精简版进行了类似的添加。此外,我还为应用程序的付费版和免费版对我的 appDelegate 添加了必要的更改:

-(BOOL)application:(UIApplication *)application
           openURL:(NSURL *)url
 sourceApplication:(NSString *)sourceApplication
        annotation:(id)annotation {

    if ([[url scheme] isEqualToString:@"myAppLinkScheme"]) {
        return YES;
    }
    ...
}

所以,我显然遗漏了一些东西。需要什么额外的实现来设置我的服务器,以便当用户从他们 iPhone 的邮件应用程序中点击指向我的服务器的链接时,他们会被重定向到我的应用程序?

最佳答案

那些<meta>标签受到已实现 Applinks 协议(protocol)并知道寻找它们的应用程序(例如 Facebook)的尊重。 Mail 和 Safari 等其他应用程序完全忽略它们,而是打开后备 URL。

当您使用移动托管 API 时,会注册该后备 URL 以打开 Facebook 应用程序。不幸的是,Facebook 之后不会将您转到您自己的应用程序。

当您使用自己的服务器时,后备只是您网站上的一个 URL...该 URL 未注册到任何内容。然而。

要解决此问题,您需要以某种不依赖于 Facebook 的方式执行链接到应用程序的重定向。有几个选项:

  1. 在您的服务器上实现 JavaScript 重定向,如下所示:

    setTimeout(function() {
      window.location = "https://itunes.apple.com/path/to/your/app/";
    }, 25);
    
    // If "yourapp://" is registered, the user will see a dialog
    // asking if want to open your app. If they agree, your app will 
    // launch  immediately and the timer won't fire.
    // If not installed, you'll get an ugly "Cannot Open Page" 
    // dialogue and the App Store will launch when the timer expires.
    
    window.location = "yourapp://";
    

    显然这不是一个理想的解决方案,它有很多令人讨厌的边缘情况,最值得注意的是,如果用户没有安装您的应用程序,他们将会看到“无法打开页面”错误。直到最近,还可以通过使用此脚本的更细致版本智能地重定向到 App Store,以相当用户友好的方式解决此问题。遗憾的是,Apple intentionally broke that 更新了 iOS 9.2。

  2. > Enable Universal Links .苹果公司知道这是一个恼人的问题,并正在努力提供帮助。通用链接允许您使用网站页面的普通 URL(解决未安装应用程序的后备问题),该 URL 会被您的手机拦截并直接发送到您的应用程序(如果已安装)。不幸的是,通用链接仅适用于 iOS 9+,并且在 a lot of apps 中打开时无法工作。 (具有讽刺意味的是,包括 Facebook)。

最好的解决方案是上述方法的组合:在所有支持的地方使用通用链接和应用程序链接,以及作为后备的智能 JavaScript 重定向。这是相当多的事情需要处理,所以最好的选择可能是像 Branch.io 这样的免费服务。 (全面披露:我与团队合作)负责所有技术方面的工作。

关于html - appLinks 不会从电子邮件中打开 iPhone 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36014989/

相关文章:

android - HTML5 地理定位在 Android 模拟器中不起作用

iphone - 在 iPhone 上打开我的应用程序的自定义 URL——就像在 Youtube 上一样

iphone - 如何在 Obj-C 类别中使用 "fake"ivars (iPhone)

iphone - 从数据创建 CMSampleBufferRef

javascript - 如何在 Angular js中的输入类型日期中显示日期?

javascript - 如何在时间进度条中放置时间显示框

ios - 当视频从所有屏幕播放完毕时自动关闭 AVPlayer

ios - 如何使用 ios sdk 在没有权限对话框的情况下登录 facebook?

ios - 使用 Xamarin 的 iOS 多路径 TCP

javascript - 将变量传递给 Javascript