婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解如何通過H5(瀏覽器/WebView/其他)喚起本地app

詳解如何通過H5(瀏覽器/WebView/其他)喚起本地app

熱門標簽:電銷機器人電話用什么卡 鎮江智能外呼系統有效果嗎 四川點撥外呼系統 南寧點撥外呼系統哪家公司做的好 江蘇智能電銷機器人哪家好 黃島區地圖標注 當涂高德地圖標注 云南大理400電話申請官方 成都智能外呼系統平臺

前兩天接到一個無線的需求,我這個小白可是忙活了好幾天……在頁面上有一個連接, 如果用戶安裝了APP,則點擊打開對應的APP如果用戶沒有安裝,則點擊打開對應的設置連接.上網搜索了一下,基本都說可以實現,但是實際情況卻不樂觀.

當然只是其中的一個需求,還有的是現在各類app,分享出去的H5頁面中,一般都會帶著一個立即打開的按鈕,如果本地安裝了app,那么就直接喚起本地的app,如果沒有安裝,則跳轉到下載。這是一個很正常的推廣和導流量的策略,最近產品經理就提出了這樣的一個需求,做一個像今日頭條功能一樣的帶打開app的下載條等等,其他的就不說了!

下面進入我們今天的正題,H5如何打開或者說喚起手機本地的app,縱觀百度和Google上面的答案,無非是兩種:

第一種方式:

通過在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,然后跳轉到下載頁。當然這不是我想出來的,是網上的各位大佬的想法。在這里又要細分為兩種情況了。

1.直接喚醒

說明:通過h5可換醒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>
<!--
說明:通過h5可換醒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>

2.點擊喚醒

說明:通過h5可換醒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>
<!--
說明:通過h5可換醒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是否安裝,這里記錄一下方法,代碼如下:

更多方法請查看我的工具類: 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 Scheme Bundle identifier
Safari http://
maps http://maps.google.com
Phone tel://
SMS sms://
Mail mailto://
iBooks ibooks://
App Store itms-apps://itunes.apple.com
Music music://
Videos videos://

2,常用第三方軟件

名稱 URL Scheme Bundle identifier
QQ mqq://
微信 weixin://
騰訊微博 TencentWeibo://
淘寶 taobao://
支付寶 alipay://
微博 sinaweibo://
weico微博 weico://
QQ瀏覽器 mqqbrowser:// com.tencent.mttlite
uc瀏覽器 dolphin:// com.dolphin.browser.iphone.chinese
歐朋瀏覽器 ohttp:// com.oupeng.mini
搜狗瀏覽器 SogouMSE:// com.sogou.SogouExplorerMobile
百度地圖 baidumap:// com.baidu.map
Chrome googlechrome://
優酷 youku://
京東 openapp.jdmoble://
人人 renren://
美團 imeituan://
1號店 wccbyihaodian://
我查查 wcc://
有道詞典 yddictproapp://
知乎 zhihu://
點評 dianping://
微盤 sinavdisk://
豆瓣fm doubanradio://
網易公開課 ntesopen://
名片全能王 camcard://
QQ音樂 qqmusic://
騰訊視頻 tenvideo://
豆瓣電影 doubanmovie://
網易云音樂 orpheus://
網易新聞 newsapp://
網易應用 apper://
網易彩票 ntescaipiao://
有道云筆記 youdaonote://
多看 duokan-reader://
全國空氣質量指數 dirtybeijing://
百度音樂 baidumusic://
下廚房 xcfapp://

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。 

標簽:佳木斯 淮安 咸寧 十堰 廣西 酒泉 南京 西寧

巨人網絡通訊聲明:本文標題《詳解如何通過H5(瀏覽器/WebView/其他)喚起本地app》,本文關鍵詞  詳解,如何,通過,瀏覽器,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解如何通過H5(瀏覽器/WebView/其他)喚起本地app》相關的同類信息!
  • 本頁收集關于詳解如何通過H5(瀏覽器/WebView/其他)喚起本地app的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    香蕉久久夜色精品国产使用方法 | 久久综合网色—综合色88| 欧美成人女星排名| 综合激情网...| 国产99久久久国产精品免费看 | 99热精品国产| 久久精品男人天堂av| 久久精品人人做| 粉嫩av亚洲一区二区图片| 精品理论电影在线| 秋霞午夜av一区二区三区| 日本丶国产丶欧美色综合| 一区二区三区中文字幕精品精品 | 高清不卡在线观看| 精品国产制服丝袜高跟| 香蕉成人啪国产精品视频综合网 | 成人免费看的视频| 欧美一级黄色片| 国产精品一区二区三区乱码| 欧美大片国产精品| 男人的j进女人的j一区| 91精品国产福利| 成年人国产精品| 亚洲日本在线看| 欧美亚洲国产一区二区三区va| 6080yy午夜一二三区久久| 国产精品一二三| 日韩视频永久免费| 美女视频免费一区| 精品国产成人在线影院| 色婷婷久久99综合精品jk白丝| 午夜精品成人在线视频| 日韩一级免费观看| 国产乱码精品1区2区3区| 欧美极品xxx| 91精品国产综合久久国产大片| 美女视频黄免费的久久| 国产午夜一区二区三区| 成人av综合在线| 国产欧美1区2区3区| 欧美精品亚洲一区二区在线播放| 久久成人麻豆午夜电影| 中日韩免费视频中文字幕| 久久99热这里只有精品| 亚洲国产精品一区二区www在线| 国产欧美日本一区二区三区| 成人高清在线视频| 亚洲制服丝袜av| 69精品人人人人| 国产成人av一区二区三区在线 | 九九视频精品免费| 国产精品伦理在线| 欧洲精品中文字幕| 91小视频在线| 精品影院一区二区久久久| 99综合电影在线视频| 日本女优在线视频一区二区| 亚洲精品大片www| 日韩毛片在线免费观看| 中文幕一区二区三区久久蜜桃| 亚洲精品一区二区三区香蕉| 日韩一区二区三区免费观看| 欧美性生活影院| 欧美在线一二三四区| 欧美性一二三区| 日本韩国欧美三级| 在线日韩一区二区| 欧美人妇做爰xxxⅹ性高电影| 精品视频在线免费观看| 56国语精品自产拍在线观看| 五月天激情小说综合| 日韩成人免费在线| 美女被吸乳得到大胸91| 国产真实乱对白精彩久久| 久久99精品久久久久久国产越南| 精东粉嫩av免费一区二区三区| 精品一区二区三区在线观看国产 | 26uuu成人网一区二区三区| 日韩精品一区二| 久久久99精品久久| ...av二区三区久久精品| 亚洲美女视频在线| 奇米色一区二区| 国产资源精品在线观看| 白白色亚洲国产精品| 欧美日韩综合在线| 精品国一区二区三区| 国产精品盗摄一区二区三区| 亚洲一区二区三区激情| 免费日韩伦理电影| proumb性欧美在线观看| 欧美亚洲国产怡红院影院| 欧美一区日韩一区| 成人一区二区三区视频| 精品一区二区三区免费毛片爱| 精品一区二区三区不卡 | 亚洲婷婷在线视频| 日韩电影免费一区| 成人精品鲁一区一区二区| 欧洲生活片亚洲生活在线观看| 91精品国产福利在线观看| 日韩一级完整毛片| 中文字幕av资源一区| 亚洲风情在线资源站| 国产成人精品免费| 欧美日韩在线免费视频| 国产亚洲午夜高清国产拍精品| 亚洲一区二区三区激情| 国产成人精品免费在线| 欧美精三区欧美精三区| 国产精品不卡一区| 激情综合色播五月| 欧美午夜不卡视频| 亚洲欧洲在线观看av| 午夜视频一区在线观看| 91小视频免费观看| 欧美激情综合五月色丁香| 蜜臀91精品一区二区三区| 91久久精品一区二区| 欧美www视频| 日韩精品一级中文字幕精品视频免费观看| 国产精华液一区二区三区| 欧美一区二区免费观在线| 亚洲精品自拍动漫在线| 福利一区二区在线| 日韩欧美在线一区二区三区| 亚洲一区二区三区视频在线| 久久爱www久久做| 91精品国产高清一区二区三区 | 久久丁香综合五月国产三级网站 | 国产一区二区视频在线播放| 欧美三级一区二区| 亚洲欧美经典视频| 9i看片成人免费高清| 国产喂奶挤奶一区二区三区| 麻豆精品久久久| 日韩视频永久免费| 免费一级欧美片在线观看| 制服丝袜av成人在线看| 日本中文字幕一区二区有限公司| 欧美熟乱第一页| 亚洲精品久久久蜜桃| av亚洲产国偷v产偷v自拍| 久久久精品免费观看| 国产毛片一区二区| 精品国产乱码91久久久久久网站| 免费xxxx性欧美18vr| 精品处破学生在线二十三| 久久99九九99精品| 精品播放一区二区| 亚洲第一福利一区| 777奇米成人网| 狠狠色丁香久久婷婷综合丁香| 欧美变态凌虐bdsm| 丰满白嫩尤物一区二区| 亚洲视频每日更新| 欧美一区二区在线免费播放| 久久不见久久见中文字幕免费| 久久精品视频一区二区| 大陆成人av片| 亚洲第一主播视频| 欧美成人一区二区三区 | 亚洲欧美激情插 | 中国色在线观看另类| 国产在线精品一区二区三区不卡 | 奇米四色…亚洲| 欧美无砖专区一中文字| 一区二区三区 在线观看视频| 欧美日韩在线电影| 国产亚洲一区二区三区| 91女人视频在线观看| 亚洲v中文字幕| 欧美tk丨vk视频| 99re亚洲国产精品| 亚洲五月六月丁香激情| 久久久国产午夜精品| 色悠久久久久综合欧美99| 亚洲成人在线网站| 国产精品久久久久影院色老大 | 欧美一卡在线观看| 国产精品88av| 亚洲1区2区3区视频| 国产精品久久99| 久久综合国产精品| 在线欧美日韩精品| 波多野结衣在线一区| 久久狠狠亚洲综合| 亚洲国产精品精华液网站| 国产精品色婷婷| www国产成人| 91色在线porny| 黄色日韩网站视频| 亚洲va韩国va欧美va精品| 中文在线一区二区| 欧美嫩在线观看| 色综合天天综合网国产成人综合天 | 亚洲乱码国产乱码精品精可以看| 精品久久久久99| 日韩一区二区三区在线观看| 色综合中文字幕国产|