如何从 Web 应用程序打开本机 iOS 应用程序

IT技术 javascript ios mobile-safari
2021-01-27 02:07:00

总结我有一个具有正常运行的 URL 方案的应用程序,我想从存储在主屏幕上的 Web 应用程序启动它,但正常的 JavaScript 重定向方法似乎不起作用。

详细信息我正在尝试创建一个 iOS 网络应用程序,从主屏幕上保存的链接以全屏模式打开。Web 应用程序需要打开特定的本机应用程序。我已经为本机应用程序注册了 url 方案,并验证它可以正常工作 - 例如,我可以通过将方案直接输入到我的 Safari 地址栏中来打开本机应用程序。我也可以使用 的+openURL:方法从其他应用程序打开它UIApplication我还想使用可以添加到主屏幕的本机 Web 应用程序中的某些参数打开它。

我想要做的是在本机应用程序中像这样使用 JavaScript:

window.location = "myapp://myparam";

在网络应用程序中使用此代码时,我收到一条警告:

“无法打开 myWebAppName - 无法打开 myWebAppName。错误是“无法显示此 URL”。”。

在 Safari 中执行时,同样的 javascript 可以正常工作。我使用window.location.replace("myapp://myparam").

Web 应用程序的 html 是:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
   "http://www.w3.org/TR/html4/strict.dtd">

<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>untitled</title>
    <meta name="generator" content="TextMate http://macromates.com/">
    <meta name="author" content="Carl Veazey">
    <!-- Date: 2012-04-19 -->
    <meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=0;" />
    <meta name="apple-mobile-web-app-capable" content="yes" />
    <meta names="apple-mobile-web-app-status-bar-style" content="black-translucent" />
</head>
<body>
    <script type="text/javascript" charset="utf-8">
        if (window.navigator.userAgent.indexOf('iPhone') != -1) {
            if (window.navigator.standalone == true) {
                window.location = "myapp://myparam";
            } else {
                document.write("please save this to your home screen");
        };} else {
                alert("Not iPhone!");
                document.location.href = 'please-open-from-an-iphone.html';
        };
    </script>
</body>
</html>

我在这里做错了什么?我对 javascript 和移动网络非常缺乏经验,所以我怀疑我只是遗漏了一些明显的东西。

5个回答

您的代码在移动 safari 中有效,但如果来自 iOS 桌面上的书签则无效。以前从未尝试过这种方式,但这就是问题所在。如果我只是将你的 JS 设置为

<script type="text/javascript" charset="utf-8"> 
window.location = "myapp://myparam";
</script>

它在浏览器中工作,但在添加书签时失败。由于没有 chrome,它可能必须对添加书签时 url 的加载方式进行处理?我的猜测是苹果不希望预订标记页面访问本地应用程序。另外,我注意到如果我为本地托管的页面添加了书签,该页面在移动 Safari 中有效,我无法通过书签加载它。真的很奇怪....

我给你的最好的建议就是去做

<meta name="apple-mobile-web-app-capable" />

代替

<meta name="apple-mobile-web-app-capable" content="yes" />

这样它就会出现在主屏幕上,但不幸的是会加载 chrome。这是我能想到的唯一解决方案。

window.navigator.standalone 是我所知道的唯一方法,它只有在启用 content="yes" 时才有效。不确定是否可以做你想做的事。我可以看到苹果故意不允许开发人员制作启动另一个应用程序的主页按钮。这有点令人困惑,因为他们应该只是点击应用程序而不是加载应用程序的网页。
2021-03-19 02:07:00
谢谢,但我怎么能有条件地执行我的 javascript?我有 if 语句检查那里的用户代理,因为我希望同一页面在从 Safari 导航到与从主屏幕启动时的行为不同。你知道有什么不同的检查方法吗?谢谢!
2021-04-02 02:07:00

如果您需要打开已安装的 iOS 应用程序并希望保留页面的功能,这location.href = 'myapp://?params=...';将无济于事,因为如果myapp://未注册,重定向会将用户引导至无法访问的目的地。

最安全的选择似乎是使用iframe. 如果已安装,以下代码将打开 iOS 应用程序,如果未安装,则不会导致失败(尽管它可能会提醒用户如果未安装该应用程序,则无法访问该页面):

var frame = document.createElement('iframe');
frame.src = 'myapp://?params=...';
frame.style.display = 'none';
document.body.appendChild(frame);

// the following is optional, just to avoid an unnecessary iframe on the page
setTimeout(function() { document.body.removeChild(frame); }, 4);
在浏览器上工作,但在电子邮件客户端浏览器上使用时,这不起作用
2021-04-10 02:07:00

试试这样:索引页

<html><head></head><body>
<?php
$app_url = urlencode('YourApp://profile/blabla');
$full_url = urlencode('http://yoursite.com/profile/bla');
?>   

<iframe src="receiver.php?mylink1=<?php echo $app_url;?>" width="1px" height="1px" scrolling="no" frameborder="0"></iframe>
<iframe src="receiver.php?mylink2=<?php echo $full_url;?>" width="1px" height="1px" scrolling="no" frameborder="0"></iframe>

</body>
</html>

receiver.php页:

<?php if ($first == $_GET['mylink1'])) { ?>
   <script type="text/javascript">
   self.window.location = "<?php echo $first;?>"; 
   </script>

<?php } if ($second == $_GET['mylink2'])) { ?>
   <script type="text/javascript">
   window.parent.location.href = "<?php echo $second ;?>"; 
   //window.top.location.href=theLocation;
   //window.top.location.replace(theLocation);
   </script>
<?php } ?>

为了提供更新,iOS14 Beta7 似乎没有通过其注册的 x 回调 URL 打开任何本地应用程序。👎

<?php 
// Detect device type
$iPod = stripos($_SERVER['HTTP_USER_AGENT'],"iPod");
$iPhone = stripos($_SERVER['HTTP_USER_AGENT'],"iPhone");

// Redirect if iPod/iPhone
if( $iPod || $iPhone ){
    header('Location:http://example.com');      
}
?>

如果设备是 iPod 或 iPhone,上面的代码会将浏览器重定向到输入的 URL (http://example.com/)。将脚本添加到 Web 应用程序的顶部,确保将其保存为.php文件而不是.html.

来源:http : //www.schiffner.com/programming-php-classes/php-mobile-device-detection/

@RyanBrodie 是的,我正在努力使用 JS 进行重定向。我会试试的。
2021-03-19 02:07:00
在你的手机上访问jsfiddle.net/W9Wp2/1,使用你的特定字符串打开,点击运行,看看它是否有效。我感觉你的 JS/HTML 不正确。
2021-03-22 02:07:00
粘贴您的 JS / HTML 会有所帮助
2021-03-24 02:07:00
它是一个网络应用程序并且它被保存在主屏幕上应该没有任何区别,只要 URL 的格式正确,您的应用程序应该打开?或者您是否正在努力使用 JS 进行重定向?如果是这样,一个简单的 JSheader.location="URL"就足够了。我不确定这是否是你所追求的。
2021-03-31 02:07:00
对不起,如果我没有说清楚。我已经完成了那部分 - 现在我需要使用 javascript 从保存在主屏幕上的网络应用程序打开我的应用程序。我想我会改写我的问题。
2021-04-04 02:07:00