網(wǎng)頁端與App端互通

最近在公司做web App項(xiàng)目宾抓,需要在webApp中打開原生App
如果本地有安裝原生App,那就直接去打開原生App對應(yīng)的頁面,如果本地沒有安裝原生App,那就直接去下載這個(gè)原生App.

先看網(wǎng)頁端的代碼

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>

    <body>
        <button onclick="doCheck()">測試設(shè)備Main2</button></br>
    </body>
    <script type="text/javascript">
        function doCheck() {
            var ua = navigator.userAgent;   
            //判斷瀏覽器的當(dāng)前設(shè)備,是iPhone,還是Android
            if(ua.indexOf('iPhone') > 0) {
                alert('iPhone設(shè)備');
            } else if(ua.indexOf('Android') > 0) {
                //alert('Android設(shè)備');
                checkAndroid();
            } else {
                alert('暫不支持你所用的系統(tǒng)对雪,請使用Android或iOS系統(tǒng)')
            }
        }

            //
        function checkAndroid() {
            //"banggu://是網(wǎng)頁與App約定的協(xié)議坏怪,這個(gè)是自由的不需要限制"
            //com.example.liuzenglong.newapp.Main2Activity 這個(gè)是我準(zhǔn)備打開對應(yīng)App的一個(gè)類
            //?id=10000&userId ='liuzenglong'&password='123456'"    //提供傳遞的參數(shù)給App
            window.location.href = "banggu://com.example.liuzenglong.newapp.Main2Activity/get/info?id=10000&userId ='liuzenglong'&password='123456'"; /***打開app的協(xié)議舱馅,有安卓同事提供***/
            window.setTimeout(function() {//這里500ms打不開App就會去下載頁下載App
                window.location.; /***打開app的下載頁***/
            }, 500);
        }
    </script>

</html>

至此網(wǎng)頁端的工作已經(jīng)做完了硅确,現(xiàn)在可以看App端铛楣,由于本人是做Android開發(fā)近迁,這里只提供Android的實(shí)現(xiàn)方式.

Android需要做的事情

1.先在AndroidManifest的配置文件配置一下打開頁面的數(shù)據(jù)

<activity android:name=".OpenFromWebActivity">
        <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:scheme="banggu" />//這個(gè)是我們對應(yīng)的協(xié)議,與網(wǎng)頁里面需要保持一致蛉艾,
        </intent-filter>
    </activity>

2. 在Activity里處理網(wǎng)頁傳遞來的數(shù)據(jù)**

/**
 * 獲取Uri
 *
 * @return
 */
private String getUri() {
    // 嘗試獲取WebApp頁面上過來的URL
    Uri uri = getIntent().getData();
    if (uri != null) {
        StringBuffer sb = new StringBuffer();
        // 完整的url信息
        sb.append("url: " + uri.toString());
        // scheme部分
        sb.append("\nscheme: " + uri.getScheme());
        // host部分   用來對應(yīng)對包名钳踊,
        sb.append("\nhost: " + uri.getHost());
        enterActivity(uri.getHost());
        // 訪問路勁
        sb.append("\npath: ");  //用來對應(yīng)模塊,
        List<String> pathSegments = uri.getPathSegments();
        for (int i = 0; pathSegments != null && i < pathSegments.size(); i++) {
            sb.append("/" + pathSegments.get(i));
        }
        // Query部分  //用來對應(yīng)模塊需要的參數(shù)
        sb.append("\nquery: ?" + uri.getQuery());

        return sb.toString();
    }
    return null;
}


/**
 * 進(jìn)入對應(yīng)的Activity
 * @param activityName
 */
private void enterActivity(String activityName) {
    try {
        Class currentClass = Class.forName(activityName);
        Toast.makeText(this, "---"+currentClass.getName(), Toast.LENGTH_SHORT).show();
        Intent intent = new Intent(this, currentClass);
        startActivity(intent);
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    }
}

這樣基本工作就已經(jīng)做完了勿侯,具體頁面拓瞪,具體操作。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末助琐,一起剝皮案震驚了整個(gè)濱河市祭埂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌兵钮,老刑警劉巖蛆橡,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異掘譬,居然都是意外死亡泰演,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門葱轩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來睦焕,“玉大人,你說我怎么就攤上這事靴拱±埃” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵袜炕,是天一觀的道長本谜。 經(jīng)常有香客問我,道長偎窘,這世上最難降的妖魔是什么乌助? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮陌知,結(jié)果婚禮上眷茁,老公的妹妹穿的比我還像新娘。我一直安慰自己纵诞,他們只是感情好上祈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般登刺。 火紅的嫁衣襯著肌膚如雪籽腕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天纸俭,我揣著相機(jī)與錄音皇耗,去河邊找鬼。 笑死揍很,一個(gè)胖子當(dāng)著我的面吹牛郎楼,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播窒悔,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼呜袁,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了简珠?” 一聲冷哼從身側(cè)響起阶界,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎聋庵,沒想到半個(gè)月后膘融,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡祭玉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年氧映,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片脱货。...
    茶點(diǎn)故事閱讀 39,991評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡岛都,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蹭劈,到底是詐尸還是另有隱情,我是刑警寧澤线召,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布铺韧,位于F島的核電站,受9級特大地震影響缓淹,放射性物質(zhì)發(fā)生泄漏哈打。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一讯壶、第九天 我趴在偏房一處隱蔽的房頂上張望料仗。 院中可真熱鬧,春花似錦伏蚊、人聲如沸立轧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氛改。三九已至帐萎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胜卤,已是汗流浹背疆导。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留葛躏,地道東北人澈段。 一個(gè)月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像舰攒,于是被迫代替她去往敵國和親败富。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,139評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理芒率,服務(wù)發(fā)現(xiàn)囤耳,斷路器,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • 名詞介紹 Native APP Native APP 指的是原生程序偶芍,一般依托于操作系統(tǒng)充择,有很強(qiáng)的交互,是一個(gè)完整...
    LabRaDor2079閱讀 1,948評論 0 5
  • 我也不知道為什么記得反正就是記得 就像我并不愿想起可總是要想起
    何不去閱讀 106評論 0 0
  • 要么讀書,要么跑步材彪,身體和靈魂總有一個(gè)在路上观挎! 發(fā)現(xiàn)群里有很多喜歡跑步的朋友,大家也可能關(guān)注過某些公號對跑步知識的...
    百日跑者孫大剩閱讀 1,507評論 49 56