URL Scheme是一种页面内跳转协议,通过定义自己的URL Scheme协议,可以实现
从一个APP中打开另外一个APP指定的页面从H5页面中跳转到APP指定的页面(实际上就是从一个浏览器中的一个页面跳转到APP指定页面)。URL Scheme协议格式: 一个完整的完整的URL Scheme协议格式由scheme、host、port、path和query组成,其结构如下所示:
<scheme>://<host>:<port>/<path>?<query>如下就是一个自定义的URL openapp://hhong:80/product?productId=10000007 openapp: 即Scheme 该Scheme协议名称(必填) hhong: 即Host,代表Scheme作用于哪个地址域(必填) 80: 即port,代表端口号 product:即path,代表打开的页面 param: 即query,代表传递的参数
传递参数的方法跟web端一样,通过问号?分隔,参数名和值之间使用等号=连接,多个参数之间使用&拼接。
Scheme使用
既然我们使用scheme来做打开app并跳转的逻辑,那这个scheme应该声明在哪里比较合适呢?如果你的应用在启动页(splash)或者在主界面(main)初始化了一些必要的设置,比如必要的token信息检查交易或者一些其它校验等,没有这些信息会造成崩溃的,这个时候我们就需要在启动页来声明这个scheme了,获取scheme信息保存起来,然后在主界面做处理逻辑,如跳转到其它界面等。当然你也可以声明scheme在其它地方,具体得需要看怎么实现业务比较方便。
#mermaid-svg-sx9rpRlAjyppgW7e .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-sx9rpRlAjyppgW7e .label text{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .node rect,#mermaid-svg-sx9rpRlAjyppgW7e .node circle,#mermaid-svg-sx9rpRlAjyppgW7e .node ellipse,#mermaid-svg-sx9rpRlAjyppgW7e .node polygon,#mermaid-svg-sx9rpRlAjyppgW7e .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-sx9rpRlAjyppgW7e .node .label{text-align:center;fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .node.clickable{cursor:pointer}#mermaid-svg-sx9rpRlAjyppgW7e .arrowheadPath{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-sx9rpRlAjyppgW7e .flowchart-link{stroke:#333;fill:none}#mermaid-svg-sx9rpRlAjyppgW7e .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-sx9rpRlAjyppgW7e .edgeLabel rect{opacity:0.9}#mermaid-svg-sx9rpRlAjyppgW7e .edgeLabel span{color:#333}#mermaid-svg-sx9rpRlAjyppgW7e .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-sx9rpRlAjyppgW7e .cluster text{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-sx9rpRlAjyppgW7e .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-sx9rpRlAjyppgW7e text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-sx9rpRlAjyppgW7e .actor-line{stroke:grey}#mermaid-svg-sx9rpRlAjyppgW7e .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-sx9rpRlAjyppgW7e .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-sx9rpRlAjyppgW7e #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-sx9rpRlAjyppgW7e .sequenceNumber{fill:#fff}#mermaid-svg-sx9rpRlAjyppgW7e #sequencenumber{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e #crosshead path{fill:#333;stroke:#333}#mermaid-svg-sx9rpRlAjyppgW7e .messageText{fill:#333;stroke:#333}#mermaid-svg-sx9rpRlAjyppgW7e .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-sx9rpRlAjyppgW7e .labelText,#mermaid-svg-sx9rpRlAjyppgW7e .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-sx9rpRlAjyppgW7e .loopText,#mermaid-svg-sx9rpRlAjyppgW7e .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-sx9rpRlAjyppgW7e .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-sx9rpRlAjyppgW7e .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-sx9rpRlAjyppgW7e .noteText,#mermaid-svg-sx9rpRlAjyppgW7e .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-sx9rpRlAjyppgW7e .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-sx9rpRlAjyppgW7e .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-sx9rpRlAjyppgW7e .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-sx9rpRlAjyppgW7e .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .section{stroke:none;opacity:0.2}#mermaid-svg-sx9rpRlAjyppgW7e .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-sx9rpRlAjyppgW7e .section2{fill:#fff400}#mermaid-svg-sx9rpRlAjyppgW7e .section1,#mermaid-svg-sx9rpRlAjyppgW7e .section3{fill:#fff;opacity:0.2}#mermaid-svg-sx9rpRlAjyppgW7e .sectionTitle0{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .sectionTitle1{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .sectionTitle2{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .sectionTitle3{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-sx9rpRlAjyppgW7e .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .grid path{stroke-width:0}#mermaid-svg-sx9rpRlAjyppgW7e .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-sx9rpRlAjyppgW7e .task{stroke-width:2}#mermaid-svg-sx9rpRlAjyppgW7e .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .taskText:not([font-size]){font-size:11px}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-sx9rpRlAjyppgW7e .task.clickable{cursor:pointer}#mermaid-svg-sx9rpRlAjyppgW7e .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-sx9rpRlAjyppgW7e .taskText0,#mermaid-svg-sx9rpRlAjyppgW7e .taskText1,#mermaid-svg-sx9rpRlAjyppgW7e .taskText2,#mermaid-svg-sx9rpRlAjyppgW7e .taskText3{fill:#fff}#mermaid-svg-sx9rpRlAjyppgW7e .task0,#mermaid-svg-sx9rpRlAjyppgW7e .task1,#mermaid-svg-sx9rpRlAjyppgW7e .task2,#mermaid-svg-sx9rpRlAjyppgW7e .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutside0,#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutside2{fill:#000}#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutside1,#mermaid-svg-sx9rpRlAjyppgW7e .taskTextOutside3{fill:#000}#mermaid-svg-sx9rpRlAjyppgW7e .active0,#mermaid-svg-sx9rpRlAjyppgW7e .active1,#mermaid-svg-sx9rpRlAjyppgW7e .active2,#mermaid-svg-sx9rpRlAjyppgW7e .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-sx9rpRlAjyppgW7e .activeText0,#mermaid-svg-sx9rpRlAjyppgW7e .activeText1,#mermaid-svg-sx9rpRlAjyppgW7e .activeText2,#mermaid-svg-sx9rpRlAjyppgW7e .activeText3{fill:#000 !important}#mermaid-svg-sx9rpRlAjyppgW7e .done0,#mermaid-svg-sx9rpRlAjyppgW7e .done1,#mermaid-svg-sx9rpRlAjyppgW7e .done2,#mermaid-svg-sx9rpRlAjyppgW7e .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-sx9rpRlAjyppgW7e .doneText0,#mermaid-svg-sx9rpRlAjyppgW7e .doneText1,#mermaid-svg-sx9rpRlAjyppgW7e .doneText2,#mermaid-svg-sx9rpRlAjyppgW7e .doneText3{fill:#000 !important}#mermaid-svg-sx9rpRlAjyppgW7e .crit0,#mermaid-svg-sx9rpRlAjyppgW7e .crit1,#mermaid-svg-sx9rpRlAjyppgW7e .crit2,#mermaid-svg-sx9rpRlAjyppgW7e .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-sx9rpRlAjyppgW7e .activeCrit0,#mermaid-svg-sx9rpRlAjyppgW7e .activeCrit1,#mermaid-svg-sx9rpRlAjyppgW7e .activeCrit2,#mermaid-svg-sx9rpRlAjyppgW7e .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-sx9rpRlAjyppgW7e .doneCrit0,#mermaid-svg-sx9rpRlAjyppgW7e .doneCrit1,#mermaid-svg-sx9rpRlAjyppgW7e .doneCrit2,#mermaid-svg-sx9rpRlAjyppgW7e .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-sx9rpRlAjyppgW7e .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-sx9rpRlAjyppgW7e .milestoneText{font-style:italic}#mermaid-svg-sx9rpRlAjyppgW7e .doneCritText0,#mermaid-svg-sx9rpRlAjyppgW7e .doneCritText1,#mermaid-svg-sx9rpRlAjyppgW7e .doneCritText2,#mermaid-svg-sx9rpRlAjyppgW7e .doneCritText3{fill:#000 !important}#mermaid-svg-sx9rpRlAjyppgW7e .activeCritText0,#mermaid-svg-sx9rpRlAjyppgW7e .activeCritText1,#mermaid-svg-sx9rpRlAjyppgW7e .activeCritText2,#mermaid-svg-sx9rpRlAjyppgW7e .activeCritText3{fill:#000 !important}#mermaid-svg-sx9rpRlAjyppgW7e .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-sx9rpRlAjyppgW7e g.classGroup text .title{font-weight:bolder}#mermaid-svg-sx9rpRlAjyppgW7e g.clickable{cursor:pointer}#mermaid-svg-sx9rpRlAjyppgW7e g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-sx9rpRlAjyppgW7e g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-sx9rpRlAjyppgW7e .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-sx9rpRlAjyppgW7e .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-sx9rpRlAjyppgW7e .dashed-line{stroke-dasharray:3}#mermaid-svg-sx9rpRlAjyppgW7e #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e .commit-id,#mermaid-svg-sx9rpRlAjyppgW7e .commit-msg,#mermaid-svg-sx9rpRlAjyppgW7e .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-sx9rpRlAjyppgW7e g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-sx9rpRlAjyppgW7e g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-sx9rpRlAjyppgW7e g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-sx9rpRlAjyppgW7e .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-sx9rpRlAjyppgW7e .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-sx9rpRlAjyppgW7e .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-sx9rpRlAjyppgW7e .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-sx9rpRlAjyppgW7e .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-sx9rpRlAjyppgW7e .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-sx9rpRlAjyppgW7e .edgeLabel text{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-sx9rpRlAjyppgW7e .node circle.state-start{fill:black;stroke:black}#mermaid-svg-sx9rpRlAjyppgW7e .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-sx9rpRlAjyppgW7e #statediagram-barbEnd{fill:#9370db}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-state .divider{stroke:#9370db}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-sx9rpRlAjyppgW7e .note-edge{stroke-dasharray:5}#mermaid-svg-sx9rpRlAjyppgW7e .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-sx9rpRlAjyppgW7e .error-icon{fill:#522}#mermaid-svg-sx9rpRlAjyppgW7e .error-text{fill:#522;stroke:#522}#mermaid-svg-sx9rpRlAjyppgW7e .edge-thickness-normal{stroke-width:2px}#mermaid-svg-sx9rpRlAjyppgW7e .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-sx9rpRlAjyppgW7e .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-sx9rpRlAjyppgW7e .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-sx9rpRlAjyppgW7e .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-sx9rpRlAjyppgW7e .marker{fill:#333}#mermaid-svg-sx9rpRlAjyppgW7e .marker.cross{stroke:#333} :root { --mermaid-font-family: "trebuchet ms", verdana, arial;} #mermaid-svg-sx9rpRlAjyppgW7e { color: rgba(0, 0, 0, 0.75); font: ; } scheme跳转 scheme跳转 APP1 APP2启动页保存参数 浏览器 APP2主页 APP2具体页面如配置SplashActivity完整的打开链接为openapp://hhong:80/product?param=100,需要在AndroidManifest.xml配置(SplashActivity启动模式为默认standard模式)
<activity android:name=".SplashActivity"> <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="hhong" android:path="/product" android:port="80" android:scheme="openapp" /> </intent-filter> </activity>定义好scheme相关的参数后,现在我们需要用scheme调起目标app,主要有两种方式
APP中打开另一个APP指定的页面 String url = "openapp://hhong:80/product?productId=10000007"; Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); //intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); String intentUri = intent.toUri(Intent.URI_INTENT_SCHEME); Log.e(TAG, "action是:" + intentUri); startActivity(intent);这种方式的跳转比较简单,也是最不容易出错的。
浏览器中的一个页面跳转到APP指定页面这种方式的跳转可能同样的代码会导致不同的结果,因为涉及到浏览器,而不同的手机厂商不能保证所有的浏览器内核是一样的,进而可能对scheme的处理也是不一样。 前提:项目用的框架是蚂蚁的MPASS,这个项目可能和正常工程项目不同,因为框架对项目的启动方式做了封装,有兴趣的同学也可以去看下这个框架。 问题:app未启动时,由微信分享出来的链接然后在华为浏览器打开这个链接跳转到指定app时(非桌面图标启动app),第一次是能正常跳转到指定页面,但是app切到后台时,再在华为浏览器打开链接发现竟然不做跳转了,只是将应用切回前台页面,但在小米手机上同样的操作,好像又是正常的,这个把我们搞得一脸懵逼,我们猜测是否和浏览器内核有关,于是我们在Android 自带WebView做scheme的跳转,发现也是正常的。
<div> <a href="openapp://hhong:80/product?productId=10000007"></a> </div>还有就是浏览器上的scheme跳转,Android这边怎么处理的呢?scheme启动Activity其实用的就是Intent,细心的你肯定发现了第一种方式:APP中打开另一个APP指定的页面的跳转,log打印了一个intentUri:
String intentUri = intent.toUri(Intent.URI_INTENT_SCHEME); Log.e(TAG, "action是:" + intentUri);打印的结果:
E/MainActivity: action是:intent://hhong:80/product?productId=10000007#Intent;scheme=openapp;end如果我们在方式1中把intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)加上,打印的结果:
E/MainActivity: action是:intent://hhong:80/product?productId=10000007#Intent;scheme=openapp;launchFlags=0x10000000;end相比之下,多了个launchFlags字段值,这个值在二次跳转起着重要作用(SplashActivity启动模默认standard),Android FLAG标识和启动模式关系可以看下这两篇文章Android Intent FLAG详解,包括其他的标记的一些解释、Android之点击Home键后再次打开导致APP重启问题,我们把项目SplashActivity的启动模式改为singleTask就完美的实现了我们的需求,此时mpass工程点击桌面图标并不会重新走开屏页SplashActivity。 其实华为推送通知跳转到指定页面时,在控制台上配置的就是这个intent,有兴趣的同学可以去看下华为推送官方文档,看下他们如何定义intent的,所以对于Android来说上面的href标签也可以写成这样:
<div> <a href="intent://hhong:80/product?productId=10000007#Intent;scheme=openapp;end"></a> </div>这两种方式是一样的效果,但是我们从华为浏览器scheme跳转打开app拦截到的intent是携带了FLAG,intent还有些其它的信息,如页面appfilterctrl、当前由哪个应用跳转的application_id。下面是我用正常工程测试浏览器scheme启动跳转app拦截到的intent(测试机是华为手机,可能不同的手机有不同的效果):
华为浏览器 intent://hhong:80/product?productId=10000007#Intent; scheme=openapp; category=android.intent.category.BROWSABLE; launchFlags=0x17000000; launchHwFlags=0x400; component=com.example.aapp/.SplashActivity;end UC浏览器 intent://hhong:80/product?productId=10000007#Intent; scheme=openapp; launchFlags=0x13000000; launchHwFlags=0x400; component=com.example.aapp/.SplashActivity;end Android 自带的WebView intent://hhong:80/product?productId=10000007#Intent; scheme=openapp; category=android.intent.category.BROWSABLE; launchFlags=0x3000000; launchHwFlags=0x400; component=com.example.aapp/.SplashActivity;end 桌面图标启动 intent:#Intent; action=android.intent.action.MAIN; category=android.intent.category.LAUNCHER; launchFlags=0x10200000; component=com.example.aapp/.SplashActivity;sourceBounds=792%201686%201044%202001;endSplashActivity的启动模式都是默认的standard,最终发现UC浏览器启动app后能正常跳转到页面,但是我再次从浏览器scheme启动app时,不会再跳转指定页面,这一点和桌面启动效果类似,点击桌面图标启动app后,再次点击只会把app切到前台。从上面可以看出主要的区别在于launchFlags,如果将SplashActivity启动模式改为singleTask、singleTop、singleInstance又会是怎样呢?
结论:测试正常工程发现如果SplashActivity的启动模式为standard,scheme二次能否跳转指定页面(能否重新创建SplashActivity)取决于浏览器内核,因为它所携带的launchFlags是不同的;如果SplashActivity的启动模式为singleTask、singleTop、singleInstance,scheme二次都能跳转指定页面,和浏览器内核(携带的launchFlags)无关,但是每次点击桌面图标时都会重新打开app,这个时候我们需要在启动页SplashActivity添加一段代码:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // if ((getIntent().getFlags() & Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT) != 0) { // finish(); // return; // } // 避免从桌面启动程序后,会重新实例化入口类的activity if (!this.isTaskRoot()) { Intent intent = getIntent(); if (intent != null) { String action = intent.getAction(); if (intent.hasCategory(Intent.CATEGORY_LAUNCHER) && Intent.ACTION_MAIN.equals(action)) { finish(); return; } } } setContentView(R.layout.activity_splash); }这样就保证了在正常工程下,兼容各种浏览器scheme的二次跳转能正常跳转到指定页面,并且每次点击桌面图标又不会重新打开app了!