返回顶部
首页 > 资讯 > 精选 >怎么通过Html5唤起本地app
  • 571
分享到

怎么通过Html5唤起本地app

2023-06-09 15:06:15 571人浏览 独家记忆
摘要

这篇文章主要介绍了怎么通过HTML5唤起本地app,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。第一种方式:通过在html的a标签里面的href中直接配置Android端的s

这篇文章主要介绍了怎么通过HTML5唤起本地app,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

第一种方式:

通过在html的a标签里面的href中直接配置Android端的schema,当然,如果有host其他的配置,跟在后面就可以了,android端配置和代码如下:

android端配置:

<activity android:name = ".MainActivity">        <intent-filter>            <action android:name = "android.intent.action.MAIN" />            <cateGory android:name = "android.intent.category.LAUNCHER" />        </intent-filter>        <intent-filter>            <action android:name="android.intent.action.VIEW"/>            <category android:name="android.intent.category.DEFAULT"/>            <category android:name="android.intent.category.BROWSABLE"/>            <data            android:host="jingewenku.com"                             android:scheme="abraham"/>        </intent-filter>    </activity>

注:如果这个是配置在启动页要和标签并列在一起,不然运行后手机app的图标会没有;注意schema协议要小写,否则会有不能响应的异常!

html代码:

<html>       <head>       <meta Http-equiv="Content-Type" content="text/html; charset=UTF-8">                       <title>Insert title here</title>       </head>         <body>             <a href="abraham://jingewenku.com/?pid=1">打开app</a><br/>        </body></html>

 这里我们来看看schema拼接协议的格式:

< a href="[scheme]://[host]/[path]?[query]">启动应用程序< /a>

各个项目含义如下所示:

scheme:判别启动的App。 ※详细后述

host:适当记述

path:传值时必须的key ※没有也可以

query:获取值的Key和Value ※没有也可以

以上就能实现打开本地的app了,当然是在app存在的情况下,否则的话没有反应。

大家可能会问上面的html代码中配置的不是android里面配置的schema协议吗?我明明没有配置pid,为什么要写这个呢?这是因为我们有些时候在唤起本地app的时候可能会向app传递一些参数,这些参数我们就可以配置在这里,我们只需要在oncreate里面获取就可以了,代码如下:

Intent intent = getIntent();    Uri uri = intent.getData();    if (uri != null) {        String pid = uri.getQueryParameter("pid");    }

如果还想要获取android里面配置的schema协议的话,还可以这样:

Uri uri = getIntent().getData();if(uri != null) { // 完整的url信息 String url = uri.toString(); Log.e(TAG, "url: "  + uri); // scheme部分 String scheme = uri.getScheme(); Log.e(TAG, "scheme: "  + scheme); // host部分 String host = uri.getHost(); Log.e(TAG, "host: "  + host); //port部分 int port = uri.getPort(); Log.e(TAG, "host: "  + port); // 访问路劲 String path = uri.getPath(); Log.e(TAG, "path: "  + path); List<String> pathSegments = uri.getPathSegments(); // Query部分 String query = uri.getQuery(); Log.e(TAG, "query: "  + query); //获取指定参数值 String goodsId = uri.getQueryParameter("goodsId"); Log.e(TAG, "goodsId: "  + goodsId);}

 如何判断一个Schema是否有效 :

PackageManager packageManager = getPackageManager();Intent intent = newIntent(Intent.ACTION_VIEW, Uri.parse("abraham://jingewenku.com:8888/goodsDetail?goodsId=10011002"));List<ResolveInfo> activities = packageManager.queryIntentActivities(intent, 0);booleanisValid = !activities.isEmpty();if(isValid) { startActivity(intent);}

这种方式也是我百度到的最多的方式,但是这样就带来了一个问题了,上面的需求说的是“在页面上有一个连接, 如果用户安装了APP,则点击打开对应的APP;如果用户没有安装,则点击打开对应的设置连接”,这明显就不符合需求了,这只能作为一些个别需求来使用了。

第二种方式:

既然通过在href配置schema协议不行,那就只能通过js代码来实现了,只有这样才能根据判断实现app有的时候就打开,没有的时候就跳转到下载链接下载。
我们知道,js是无法判断手机是否安装了某款app的,所以我们只能够曲线救国了,我们可以获取时间如果,长时间不能呼起app则默认为没有安装这款app,然后跳转到下载页。当然这不是我想出来的,是网上的各位大佬的想法。在这里又要细分为两种情况了。

直接唤醒

说明:通过h6可换醒app,如访问一个URL,点击按钮,打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面,通过点击的方式兼容性较好,如果安装了app,在手机各大浏览器(360浏览器、uc浏览器、搜狗浏览器、QQ浏览器、百度浏览器 )和QQ客户端中,能唤醒。微信、新浪微博客户端、腾讯微博客户端无法唤醒。

代码如下:

<html xmlns=http://www.w3.org/1999/xhtml><head><meta http-equiv=Content-Type content="text/html;charset=utf-8"><head><script src="http://libs.baidu.com/Jquery/1.9.0/jquery.js"></script><title>点击唤醒demo</title></head><body><style>#zjmobliestart{font-size:40px;}</style><!--说明:通过h6可换醒app,如访问一个URL,点击按钮,打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面,通过点击的方式。兼容性较好,如果安装了app,在手机各大浏览器(360浏览器 uc浏览器 搜狗浏览器 QQ浏览器 百度浏览器 )和QQ客户端中,能唤醒。微信 新浪微博客户端 腾讯微博客户端无法唤醒。--><a href="zjmobile://platfORMapi/startapp" id="zjmobliestart" target="_blank">唤醒浙江移动手机营业厅!</a><script type="text/javascript"> function applink(){      return function(){          var clickedAt = +new Date;           setTimeout(function(){             !window.document.WEBkitHidden && setTimeout(function(){                    if (+new Date - clickedAt < 2000){                         window.location = 'https://itunes.apple.com/us/app/zhe-jiang-yi-dong-shou-ji/id898243566#weixin.qq.com';                     }               }, 500);                }, 500)       };  }  document.getElementById("zjmobliestart").onclick = applink();  </script>   </body></html>

点击唤醒

说明:通过h6可换醒app,如访问一个URL就能直接打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面。兼容性一般:在手机各大浏览器(360浏览器、uc浏览器、搜狗浏览器 QQ浏览器、百度浏览器 )能唤醒。微信、QQ客户端、新浪微博客户端、 腾讯微博客户端无法唤醒。

代码如下:

<!Doctype html><html xmlns=http://www.w3.org/1999/xhtml><head><meta http-equiv=Content-Type content="text/html;charset=utf-8"><head><script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script><title>直接唤醒demo</title></head><body><style>#zjmobliestart{font-size:40px;}</style><!--说明:通过h6可换醒app,如访问一个URL就能直接打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面兼容性一般:在手机各大浏览器(360浏览器 uc浏览器 搜狗浏览器 QQ浏览器 百度浏览器 )能唤醒。微信 QQ客户端 新浪微博客户端 腾讯微博客户端无法唤醒。--><p id="zjmobliestart">唤醒浙江移动手机营业厅!</p><script type="text/javascript"> function applink(){       window.location = 'zjmobile://platformapi/startapp';          var clickedAt = +new Date;           setTimeout(function(){             !window.document.webkitHidden && setTimeout(function(){                    if (+new Date - clickedAt < 2000){                         window.location = 'https://itunes.apple.com/us/app/zhe-jiang-yi-dong-shou-ji/id898243566#weixin.qq.com';                     }               }, 500);                }, 500)   }applink();</script>   </body></html>

 这样就完成了我们的需求了,在这个过程中,也遇到了很多热心人的讲解,这里记录一下,刚开始有人没理解我的需求,以为我是在android端来实现,让我通过包名的方式来检验app是否安装,这里记录一下方法,代码如下:

怎么通过Html5唤起本地app

更多方法请查看我的工具类: CommonUtilLibrary

还有的就是以为我是要在app里面通过加载webview的形式来唤起本地的app,这里也记录一下,代码如下:

webView.setWebViewClient(new WebViewClient(){             @Override public boolean shouldOverrideUrlLoading(WebView view, String url) {                     Uri uri=Uri.parse(url);                   if(uri.getScheme().equals("abraham")&&uri.getHost().equals("jingewenku.com")){                             String arg0=uri.getQueryParameter("arg0");                           String arg1=uri.getQueryParameter("arg1");                       }else{           view.loadUrl(url);         } return true; }});

还要注意的是,如果是在微信中唤起本地app,手机的微信中,是利用微信内置的浏览器(你可以将之前获取的页面在服务器上的地址发给你的任何联系人,点击发送的消息即可打开网页)打开那个简单的HTML页面,注意:直接打开scheme://host/datastring是不可行的,微信不会把这串字符解析成网址,必须包装成网页才能借助微信的浏览器打开。进入后就是我们刚刚设计的页面。这个时候,直接点击“启动应用程序”是不会唤醒之前安装的APP的,因为微信做了屏蔽,你需要在右上角的菜单中选择“在浏览器中打开”。这个时候,有些浏览器就可以唤醒,有些浏览器则不行,比如笔者测试机MX4上的内置浏览器不行,UC浏览器就能唤醒。部分浏览器不能唤醒,笔者查阅了很多资料也不能彻底解决,我现在唯一能想到的是将遇到问题的浏览器让前端做一个判断,提示不支持,应该使用什么浏览器。如果有读者有解决方案,敬请留言,多谢!

后记:

微信中为什么无法唤醒App,需要“用浏览器打开”?

因为微信对所有的分享连接做了scheme屏蔽,也就是说分享连接中所有对于scheme的调用都被微信封掉了。

那为什么有些应用是可以唤起的,比如大众点评,嘀嘀打车?

从非技术角度讲,因为大众点评,嘀嘀打车都是微信的干儿子,亲儿子。对于儿子有特殊照顾。

从技术角度讲,微信有一个白名单,对于在白名单中的分享连接是不会屏蔽掉scheme调用的。

听不明白?那我们举一个例子。

比如大众点评的分享连接是 http://dazhongdianping.share.1.com

对应到微信白名单中就会有 http://dazhongdianping 这一项,所有源自于这个连接的分享,都不会屏蔽scheme,

比如 http://dazhongdianping.share.2.com
http://dazhongdianping.share.3.com

就算是大众点评的子公司也可以http://zigongsi.dazhongdianping.share.3.com,根域名也在白名单中,所以也可以使用。

到这里,大家就应该明白,想借用大众点评的scheme,绕过这个问题是不可能的,除非你的分享连接能挂到大众点评的根域名上。

这个问题应该解释清楚了,另外提一句,对于下载apk这种,微信是屏蔽任何应用的,对于儿子也不例外,所以你想提供下载链接,无论你是不是儿子,都逃不过使用浏览器打开之中low的方式了.

附录:常见应用的URL Scheme

1,系统默认应用

名称URL SchemeBundle identifier
Safarihttp://&emsp;
mapshttp://maps.google.com&emsp;
Phonetel://&emsp;
SMSsms://&emsp;
Mailmailto://&emsp;
iBooksibooks://&emsp;
App Storeitms-apps://itunes.apple.com&emsp;
Musicmusic://&emsp;
Videosvideos://&emsp;

2,常用第三方软件

名称URL SchemeBundle identifier
QQMQq://&emsp;
微信weixin://&emsp;
腾讯微博TencentWeibo://&emsp;
淘宝taobao://&emsp;
支付宝alipay://&emsp;
微博sinaweibo://&emsp;
weico微博weico://&emsp;
QQ浏览器mqqbrowser://com.tencent.mttlite
uc浏览器dolphin://com.dolphin.browser.iphone.chinese
欧朋浏览器ohttp://com.oupeng.mini
搜狗浏览器SogouMSE://com.sogou.SogouExplorerMobile
百度地图baidumap://com.baidu.map
Chromegooglechrome://&emsp;
优酷youku://&emsp;
京东openapp.jdmoble://&emsp;
人人renren://&emsp;
美团imeituan://&emsp;
1号店wccbyihaodian://&emsp;
我查查wcc://&emsp;
有道词典yddictproapp://&emsp;
知乎zhihu://&emsp;
点评dianping://&emsp;
微盘sinavdisk://&emsp;
豆瓣fmdoubanradio://&emsp;
网易公开课ntesopen://&emsp;
名片全能王camcard://&emsp;
QQ音乐qqmusic://&emsp;
腾讯视频tenvideo://&emsp;
豆瓣电影doubanmovie://&emsp;
网易云音乐orpheus://&emsp;
网易新闻newsapp://&emsp;
网易应用apper://&emsp;
网易彩票ntescaipiao://&emsp;
有道云笔记youdaonote://&emsp;
多看duokan-reader://&emsp;
全国空气质量指数dirtybeijing://&emsp;
百度音乐baidumusic://&emsp;
下厨房xcfapp://&emsp;

感谢你能够认真阅读完这篇文章,希望小编分享的“怎么通过Html5唤起本地app”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: 怎么通过Html5唤起本地app

本文链接: https://lsjlt.com/news/256535.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么通过Html5唤起本地app
    这篇文章主要介绍了怎么通过Html5唤起本地app,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。第一种方式:通过在html的a标签里面的href中直接配置android端的s...
    99+
    2023-06-09
  • Html5中如何唤起百度地图App
    这篇文章将为大家详细讲解有关Html5中如何唤起百度地图App,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最近接手了一个需求,要求混合式开发,前端做好 h6 后将页面嵌入到 ios 和 android ...
    99+
    2023-06-09
  • 怎么在html5中唤醒APP
    怎么在html5中唤醒APP?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。<!DOCTYPE html><html lang="...
    99+
    2023-06-09
  • 微信如何通过html5页面直接打开本地app
    这篇文章主要为大家展示了“微信如何通过html5页面直接打开本地app”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“微信如何通过html5页面直接打开本地app...
    99+
    2024-04-02
  • HTML5怎么打开本地app应用
    本篇内容介绍了“HTML5怎么打开本地app应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先为了保证...
    99+
    2024-04-02
  • HTML5页面怎么调起APP
    本篇内容主要讲解“HTML5页面怎么调起APP”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5页面怎么调起APP”吧!   标签:iframe app...
    99+
    2024-04-02
  • html5怎么实现外部浏览器唤起微信
    本篇内容主要讲解“html5怎么实现外部浏览器唤起微信”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么实现外部浏览器唤起微信”吧!html 部分:<script sr...
    99+
    2023-06-27
  • Uniapp怎么打包本地app
    Uniapp是一款非常流行的跨平台开发框架,它可以让开发人员使用一套代码来开发同时支持iOS、Android和Web的应用。但是,当开发人员需要将Uniapp应用打包成本地应用时,就需要特殊的步骤与技巧。本文将介绍如何将Uniapp应用打包...
    99+
    2023-05-14
  • 怎么在HTML5中实现外部浏览器唤起微信分享
    本篇文章为大家展示了怎么在HTML5中实现外部浏览器唤起微信分享,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。html部分:<script src="mshare.js&q...
    99+
    2023-06-09
  • 通过Html网页调用本地安卓(android)app程序代码
    一、通过html页面打开Android本地的app 1、首先在编写一个简单的html页面 代码如下:<html>     <h...
    99+
    2022-06-06
    html网页 HTML 调用 app Android
  • HTML5中外部浏览器唤起微信分享功能怎么实现
    小编给大家分享一下HTML5中外部浏览器唤起微信分享功能怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近在做一个手机站,要求点击分享可以直接打开微信分享...
    99+
    2023-06-09
  • 怎么通过本地电脑连接云主机
    要通过本地电脑连接云主机,您可以按照以下步骤进行操作:1. 确保您已经购买了云主机并获取了相关的登录信息,包括IP地址、用户名和密码...
    99+
    2023-09-08
    云主机
  • html5怎么通过postMessage进行跨域通信
    本篇内容主要讲解“html5怎么通过postMessage进行跨域通信”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么通过postMessage进行...
    99+
    2024-04-02
  • Idea怎么通过本地license server授权服务器
    要通过本地许可证服务器授权服务器,可以按照以下步骤进行操作: 首先,需要准备一个本地许可证服务器,该服务器应该有一个唯一标识码(...
    99+
    2023-10-23
    Idea 服务器
  • 使用Holer怎么通过外网访问本地SpringBoot
    本篇文章给大家分享的是有关使用Holer怎么通过外网访问本地SpringBoot,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1. 准备工作1.1 安装Java 1.7及以上版...
    99+
    2023-06-02
  • 通过holer怎么从外网访问本地数据库
    通过holer怎么从外网访问本地数据库,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 准备工作1.1 安装并启动数据库默认安装的数据库端口...
    99+
    2024-04-02
  • Html5中本地存储IndexedDB怎么用
    这篇文章将为大家详细讲解有关Html5中本地存储IndexedDB怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。IndexedDB 是一种低级API,用于客户端存储...
    99+
    2024-04-02
  • HTML5中LocalStorage本地存储怎么用
    这篇文章给大家分享的是有关HTML5中LocalStorage本地存储怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.前言HTML5 storage提供了一种方式让网站能...
    99+
    2024-04-02
  • html5中web本地存储怎么用
    这篇文章主要介绍了html5中web本地存储怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 在html5...
    99+
    2024-04-02
  • html5怎么通过document.head获取head元素
    本篇内容主要讲解“html5怎么通过document.head获取head元素”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么通过document....
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作