我在 android studio 中使用 webview 创建了一个简单的网站应用,并且还提供了互联网访问权限应用
上的启用了java脚本当我使用此代码添加WhatsApp共享按钮时
<button>
<a href="whatsapp://send?text=HERE GOES THE URL ENCODED TEXT YOU WANT TO SHARE" data-action="share/whatsapp/share">Share via Whatsapp</a>
</button>
这在所有移动浏览器中运行良好,但当我尝试在我的应用上使用此功能时,我收到错误信息屏幕
网页不可用
网页 在WhatsApp的://发送文本=我%20interested%20英寸%20your%20car%20for%20salecould? 没有加载,因为:
净:: ERR_UNKNOWN_URL_SCHEME
这是我在mainactivity.java中的代码
package com.a4extras.ukzz.whatsappdaily;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends AppCompatActivity {
private WebView mywebView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mywebView = (WebView)findViewById(R.id.WebView);
WebSettings webSettings = mywebView.getSettings();
webSettings.setJavaScriptEnabled(true);
mywebView.loadUrl("http://ukzz4u.blogspot.com/2017/11/whatsapp-share-01.html");
mywebView.setWebViewClient(new WebViewClient());
}
@Override
public void onBackPressed() {
if (mywebView.canGoBack()) {
mywebView.goBack();
} else {
super.onBackPressed();
}
}}
这是因为我的应用程序将whatsapp://作为URL 那么如何防止这种情况,以便Share按钮正常工作
请帮我提供必要的脚本 感谢
答案 0 :(得分:1)
简单的解决方法是在href
中使用 javascript :
<a href="javascript:go('whatsapp://send?text=HERE')">Share</a>
或者,如果使用基于Chrome的网页浏览:
<a href="intent://send?text=HERE#Intent;scheme=whatsapp;package=com.whatsapp;end">Share</a>
更复杂但更强大的解决方案是自己控制whatsapp方案:
在您的WebViewClient中:
@Override
public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
Uri uri = request.getUrl();
if (Objects.equals(uri.getScheme(), "whatsapp")) {
try {
Intent intent = Intent.parseUri(request.getUrl().toString(), Intent.URI_INTENT_SCHEME);
if(intent.resolveActivity(getPackageManager()) != null)
startActivity(intent);
return true;
} catch (URISyntaxException e) {
e.printStackTrace();
}
}
return super.shouldOverrideUrlLoading(view, request);
}