android webview加载支付宝链接失败:net::ERR_UNKNOWN_URL_SCHEME问题详解及解决方案
在Android开发中,使用WebView加载包含自定义URL scheme的链接(例如支付宝的alipays://)时,常常遇到net::ERR_UNKNOWN_URL_SCHEME错误,导致页面无法正常加载。即使重写了shouldOverrideUrlLoading方法,仍然可能在onReceivedError回调中收到errorCode为-10的错误。这是因为Android WebView默认不支持自定义URL scheme,需要开发者手动处理。
根本原因在于WebView无法识别和处理alipays://等自定义协议。仅仅重写shouldOverrideUrlLoading方法不足以解决问题,关键在于正确拦截并处理该自定义协议链接。
解决方案:使用Intent拦截并处理自定义URL scheme
通过重写WebViewClient的shouldOverrideUrlLoading方法,拦截包含alipays://的URL,并使用Intent将其交给相应的应用程序处理。
以下代码片段演示了如何实现:
webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { if (url.startsWith("alipays://")) { // 处理自定义URL scheme Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); try { startActivity(intent); } catch (ActivityNotFoundException e) { // 设备未安装可处理该URL的应用 // 可在此处添加错误处理逻辑,例如提示用户安装支付宝 e.printStackTrace(); } return true; // 已处理该URL,WebView不再加载 } // 其他URL,使用WebView默认行为 return super.shouldOverrideUrlLoading(view, url); } @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { super.onReceivedError(view, errorCode, description, failingUrl); // 可在此处添加更详细的错误处理逻辑 } });
代码首先检查URL是否以alipays://开头。如果是,则创建Intent,使用ACTION_VIEW动作和Uri.parse(url)生成的Uri对象,尝试启动相应的Activity处理支付宝链接。try-catch块处理ActivityNotFoundException,即设备未安装可处理该URL scheme的应用的情况。return true表示已处理该URL,WebView不再加载。如果不是自定义scheme,则调用父类的shouldOverrideUrlLoading方法,使用WebView默认行为。
通过此方法,即可正确拦截和处理支付宝支付链接,避免net::ERR_UNKNOWN_URL_SCHEME错误。 onReceivedError方法中的错误处理逻辑可根据实际需求调整。