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已经被杀掉。
<activity
android:name=".activity.RouterActivity"
android:theme="@android:style/Theme.NoDisplay">
<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="router" android:host="xxx.xxx.com" />
</intent-filter>
</activity>
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、微信中提示浏览器打开。微信浏览器禁止app下载链接怎么办
5、为了和app内部activity之间跳转统一,可以参考ActivityRouter开源项目。只不过注解只需一个value值,就是cmd的值。拦截器中就可以直接使用Routers.open(),不用 if else判断。
6、路由统一规划设想流程图