解决webview内的iframe中的事件不可用的问题
2020-03-28 12:38
4672 查看
最近做Android的Webview开发,使用iframe中嵌入了很多页面,嵌入的页面却不可用,最后发现是
webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { return super.shouldOverrideUrlLoading(view, url); }
不要覆写
shouldOverrideUrlLoading
这个方法,覆写这个方法会拦截ifame中的事件。
补充知识:Android 原生WebView访问使用iFrame网页问题(页面找不到了)
问题:
项目使用原生WebView访问使用了iFrame的网页出现的问题,列表页使用iFrame跳转到淘宝客的地址,单独访问淘宝客地址是能够打开。但列表页跳转过去总是提示“页面找不到了”,尝试很多方法,最终发现是WebView对第三方Cookie支持的问题。
解决:
if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP)
CookieManager.getInstance().setAcceptThirdPartyCookies(mWebView, true);
完整配置:
mWebView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } @Override public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) { handler.proceed(); super.onReceivedSslError(view, handler, error); } @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { return super.shouldOverrideUrlLoading(view, url); } @TargetApi(Build.VERSION_CODES.LOLLIPOP) @Override public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) { return super.shouldInterceptRequest(view, request); } @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); if (null != title && null != view && TextUtils.isEmpty(mTitle)) title.setText(view.getTitle()); } }); mWebView.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView webView, int i) { super.onProgressChanged(webView, i); } @Override public boolean onJsConfirm(WebView view, String url, String message, android.webkit.JsResult result) { return super.onJsConfirm(view, url, message, result); } @Override public void onShowCustomView(View view, CustomViewCallback callback) { super.onShowCustomView(view, callback); } @Override public void onHideCustomView() { } @Override public boolean onShowFileChooser(WebView webView, android.webkit.ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { return super.onShowFileChooser(webView, filePathCallback, fileChooserParams); } @Override public boolean onJsAlert(WebView view, String url, String message, android.webkit.JsResult result) { return super.onJsAlert(view, url, message, result); } @Override public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); } } ); WebSettings mWebSettings = mWebView.getSettings(); mWebSettings.setAllowFileAccess(true); mWebSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS); mWebSettings.setSupportZoom(true); mWebSettings.setBuiltInZoomControls(true); mWebSettings.setUseWideViewPort(true); mWebSettings.setSupportMultipleWindows(false); mWebSettings.setAppCacheEnabled(true); mWebSettings.setDomStorageEnabled(true); mWebSettings.setJavaScriptEnabled(true); mWebSettings.setGeolocationEnabled(true); mWebSettings.setAppCacheMaxSize(Long.MAX_VALUE); mWebSettings.setAppCachePath(getDir("appcache", 0).getPath()); mWebSettings.setDatabasePath(getDir("databases", 0).getPath()); mWebSettings.setGeolocationDatabasePath(getDir("geolocation", 0) .getPath()); mWebSettings.setPluginState(WebSettings.PluginState.ON_DEMAND); mWebSettings.setLoadWithOverviewMode(true); mWebSettings.setCacheMode(WebSettings.LOAD_NO_CACHE); String mUserAgent = mWebSettings.getUserAgentString(); mWebSettings.setUserAgentString(mUserAgent + " App/AppName"); syncCookie(); mWebSettings.setUseWideViewPort(true); mWebSettings.setLoadWithOverviewMode(true); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { mWebSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); } else { mWebSettings.setCacheMode(WebSettings.LOAD_DEFAULT); } if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { mWebSettings.setDisplayZoomControls(false); } if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { mWebSettings.setLoadsImagesAutomatically(true); } else { mWebSettings.setLoadsImagesAutomatically(false); } if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { mWebSettings.setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW); } if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) CookieManager.getInstance().setAcceptThirdPartyCookies(mWebView, true); mWebView.setScrollBarStyle(WebView.SCROLLBARS_INSIDE_OVERLAY); mWebView.setHorizontalScrollBarEnabled(false); mWebView.setHorizontalFadingEdgeEnabled(false); mWebView.setVerticalFadingEdgeEnabled(false); mWebView.requestFocus(); private void syncCookie() { CookieSyncManager.createInstance(this); CookieManager cookieManager = CookieManager.getInstance(); cookieManager.setAcceptCookie(true); CookieSyncManager.getInstance().sync(); }
以上这篇解决webview内的iframe中的事件不可用的问题就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:
相关文章推荐
- 解决小米系统下ViewPager、ScrollView内嵌套WebView时,Touch事件不响应的问题
- android Webview中注入js,用于解决第三方页中出现返回事件window.history.go(-1),无法响应问题
- webview内的iframe中的事件不可用
- android用webview加载H5页面出现点击事件失效的问题解决
- Android WebView点击EditText时整体被拉伸变大问题的解决
- 使用webView访问https的url-处理SslError解决android2.2版本之前的https请求问题
- 【webview】android webview 显示空白页问题解决
- 转 [开发总结]WebView使用中遇到的一些问题&解决
- QML使用WebView遇到的QSslSocket问题解决
- 解决CCScrollView中菜单条目在不可见时仍响应点击事件的问题
- Android WebView 解决html中文乱码问题
- asp.net GirdView按钮变为图片时画面和事件执多次问题(已解决)
- WebView 解决中文乱码问题
- webview使用sslError解决https跳转报错的问题
- 【Android】4.04系统WebView播放不了Flash问题的解决办法
- [开发总结]WebView使用中遇到的一些问题&解决
- Android webview解决图片过大出现水平滚动条的问题
- 解决Android4.4 webview 图片如何自适应 之前的方法失效问题
- 使用Jquery的鲜活绑定(lively-ness),解决“新添加的元素,事件不可用”的问题
- WebView-显示HTML内容-解决乱码问题