Android targetSdkVersion 24的Webview中出错

Android targetSdkVersion 24的Webview中出错,android,iframe,webview,android-webview,Android,Iframe,Webview,Android Webview,我的应用程序有一个WebView,它加载一个简单的HTML页面,其中包含一个iFrame,用于加载合作伙伴公司支付流程的URL(我无法访问该URL源) 当我将targetSdkVersion指向19时,一切正常,我可以通过iFrame付款。然而,当targetSdkVersion指向24时,我就没有那么幸运了 在这种情况下,WebView设法加载iFrame,其中显示了一些EditText用于输入信用卡信息和一个按钮来提交信息,但当我单击该按钮时,总是出现错误500 由于支付URL是外包的,我联

我的应用程序有一个
WebView
,它加载一个简单的HTML页面,其中包含一个iFrame,用于加载合作伙伴公司支付流程的URL(我无法访问该URL源)

当我将
targetSdkVersion
指向19时,一切正常,我可以通过iFrame付款。然而,当
targetSdkVersion
指向24时,我就没有那么幸运了

在这种情况下,
WebView
设法加载iFrame,其中显示了一些
EditText
用于输入信用卡信息和一个
按钮来提交信息,但当我单击该按钮时,总是出现错误500

由于支付URL是外包的,我联系了我们的合作伙伴公司,从500错误中了解了origem。他们告诉我错误来自一个双重调用,这使我认为api 24的
WebView
中的某些东西正在这样做

500错误的打印:

HTML
文件
payment\u HTML
如下所示:

<html>
    <head>
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
    </head>

    <body id="bodyContent" onload="addListener()" style="margin:0px;padding:0px;overflow:hidden;height:355px">
        <iframe id="ifrPagamento" src="partner_url"
            frameborder="0" style="overflow:hidden;width:100%;height:100%"></iframe>
    </body>

    <script type="text/javascript">

        function addListener() {
            window.addEventListener("message", receiveMessage, false);
        }

        function receiveMessage(message) {

            if (message) {

                var data = JSON.parse(message.data);

                if (data.code) {

                    if(data.code === "0") {
                        app.returnStatus(0);
                    }
                    else {
                        app.returnStatus(1);
                    }
                }

            }

        }

    </script>
</html>
private void setupWebView() {

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
        WebView.setWebContentsDebuggingEnabled(true);
    }

    WebSettings webSettings = mWebView.getSettings();
    webSettings.setJavaScriptEnabled(true);
    webSettings.setSupportMultipleWindows(true);
    webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    webSettings.setUseWideViewPort(true);
    webSettings.setLoadWithOverviewMode(true);
    webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
    webSettings.setAllowUniversalAccessFromFileURLs(true);
    webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
    webSettings.setAppCacheEnabled(false);
    webSettings.setDomStorageEnabled(true);

    mWebView.setWebChromeClient(new WebChromeClient());
    mWebView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
    mWebView.addJavascriptInterface(new MyJavaScriptInterface(mActivity), "app");

    mWebView.setWebViewClient(new WebViewClient() {

        @SuppressWarnings("deprecation")
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            return true;
        }

        @Override
        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
            view.loadUrl(request.getUrl().toString());
            return true;
        }

    });

}
我将
WebView
设置如下:

<html>
    <head>
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
    </head>

    <body id="bodyContent" onload="addListener()" style="margin:0px;padding:0px;overflow:hidden;height:355px">
        <iframe id="ifrPagamento" src="partner_url"
            frameborder="0" style="overflow:hidden;width:100%;height:100%"></iframe>
    </body>

    <script type="text/javascript">

        function addListener() {
            window.addEventListener("message", receiveMessage, false);
        }

        function receiveMessage(message) {

            if (message) {

                var data = JSON.parse(message.data);

                if (data.code) {

                    if(data.code === "0") {
                        app.returnStatus(0);
                    }
                    else {
                        app.returnStatus(1);
                    }
                }

            }

        }

    </script>
</html>
private void setupWebView() {

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
        WebView.setWebContentsDebuggingEnabled(true);
    }

    WebSettings webSettings = mWebView.getSettings();
    webSettings.setJavaScriptEnabled(true);
    webSettings.setSupportMultipleWindows(true);
    webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    webSettings.setUseWideViewPort(true);
    webSettings.setLoadWithOverviewMode(true);
    webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
    webSettings.setAllowUniversalAccessFromFileURLs(true);
    webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
    webSettings.setAppCacheEnabled(false);
    webSettings.setDomStorageEnabled(true);

    mWebView.setWebChromeClient(new WebChromeClient());
    mWebView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
    mWebView.addJavascriptInterface(new MyJavaScriptInterface(mActivity), "app");

    mWebView.setWebViewClient(new WebViewClient() {

        @SuppressWarnings("deprecation")
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            return true;
        }

        @Override
        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
            view.loadUrl(request.getUrl().toString());
            return true;
        }

    });

}
最后是
layout.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingTop="10dp"
    android:paddingBottom="10dp"
    android:background="@color/white">

    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="none">

    </WebView>

    <ProgressBar
        android:id="@+id/progress"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:visibility="gone"/>

</RelativeLayout>

正如我之前所说,我没有url的来源,因为它是外包的。所以我不能分享


我已经为这个问题挣扎了几个星期。有人能帮我吗?

几周后,我发现了这一点,解释了api 21的变化。请看一下
WebView
部分,其中说明:

如果应用程序使用API级别21或更高版本:

  • 默认情况下,系统锁定混合内容和第三方cookie。到 允许混合内容和第三方cookie,请使用以下方法
    分别为setMixedContentMode()和setAcceptThirdPartyCookies()
因此,我只在
WebView
中添加了这些配置,而且效果非常好

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

    webSettings.setMixedContentMode(MIXED_CONTENT_ALWAYS_ALLOW);
    CookieManager.getInstance().setAcceptThirdPartyCookies(mWebView, true);

}

如果(Build.VERSION.SDK_INT>=Build.VERSION_CODES.KITKAT){WebView.setwebcontentsdebuggingdenabled(true);}不是这样,请删除此行并签入api 24。该行仅允许通过浏览器进行调试,并且仅适用于KITKAT及更高版本。它是否适用于api 23?@PravinD No。它仅适用于api 20,即KITKAT。从api 21开始,它不再工作。尝试覆盖仅应覆盖url(WebView视图,字符串url),我知道它已被弃用,但只想让您尝试。是的,本打算回答Android已升级其安全策略,但找到了您的答案,这正是我的观点。