1、webview跳启动activity 限制:webview如果设置了WebViewClient,无论自定义协议还是http(s)协议,点击链接无法启动activity, 必须在shouldOverrideUrlLoading方法中根据url过滤,手动启动activity。所以App内部跳转使用手动拦
截器实现。 需实现效果:有对应的activity实现,就启动activity,没有的话就正常访问点击的链接。2、系统浏览器跳启动activity 限制:只能是自定义协议才能启动,http(s)无法启动。所以AndroidManifest.xml中Activity排除使用http(s) 协议。 需实现效果:能启动Activity就启动,不能启动的话就正常访问点击的链接。
3、第三方app webview跳启动activity 限制:不能启动activity,不能下载,只能浏览。 需实现效果:url能跳转可访问地址则正常访问,如果是404,就重定向到下载界面,下载界面会根据是否是 微信来显示友好提示(在系统浏览器打开)还是下载。或者直接提示在浏览器中打开。
最终目的是闭环到app上,没有app的情况url能跳转则跳转,404则重定向到下载界面。
策略:
1、正常的url增加参数标识,字段越来短越好。如cmd=xxx; 拦截器中根据这个来跳转。
2、用自定义协议配置一个跳转RouterActivity,也可以在HomeActivity中处理,在该Activity中用拦截器跳 转。不过最好是在RouterActivity中,这样可以向JumpActivity中那样判断是否app已经被杀掉。
public class RouterActivity extends BaseActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Uri uri = getIntent().getData(); if (uri != null) { UrlInterceptorManager.getInstance().interceptBBS(this, uri.toString()); } finish(); }}
3、html界面加载完成后每次都尝试启动activity;点击htlm链接,该链接要有cmd参数,如果是在app内部,webview的shouldOverrideUrlLoading方法中拦截器跳转;如果是系统浏览器,正常跳转,但是到新界面会尝试打开Activity,注意自定义协议的链接也要有cmd。
if(navigator.userAgent.match(/android/i)) { var ifrSrc ='router://xxx.xxx.com/appstore/startnewpage?cmd=chatactivity'; var ifr = document.createElement('iframe'); ifr.src = ifrSrc; ifr.style.display = 'none'; document.body.appendChild(ifr); setTimeout(function() { document.body.removeChild(ifr); }, 1500); }
4、微信中提示浏览器打开。
5、为了和app内部activity之间跳转统一,可以参考开源项目。只不过注解只需一个value值,就是cmd的值。拦截器中就可以直接使用Routers.open(),不用 if else判断。
6、路由统一规划设想流程图