Android WebView拦截url,视频播放加载失败的问题

阅读: 评论:0

Android WebView拦截url,视频播放加载失败的问题

Android WebView拦截url,视频播放加载失败的问题

需求:Android调用webView加载网页的时候,拦截某一个链接不执行此链接,执行指定跳转到其他activity页面。

webview的setWebViewClient方法中提供了几个api:

    // 此回调是拦截点击要跳转的url链接,并对请求的url链接做修改(添加删除字段)
public WebResourceResponse shouldInterceptRequest(WebView view, String url) // 在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。
public boolean shouldOverrideUrlLoading(WebView view, String url)

所以我的需求就是在shouldOverrideUrlLoading方法中做处理

webView.setWebViewClient(new WebViewClient() {@Override// 在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。public boolean shouldOverrideUrlLoading(WebView view, String url) {// 判断url链接中是否含有某个字段,如果有就执行指定的跳转(不执行跳转url链接),如果没有就加载url链接if (ains("/mproduct-")) {Intent i = new Intent(MainActivity.this, MainActivity.class);startActivity(i);return true;} else {return false;}}});

webview的一些其他设置

//点击返回键,返回上一个页面,而不是退出程序public boolean onKeyDown(int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_BACK && webView.canGoBack()) {Back();// 返回前一个页面return true;}KeyDown(keyCode, event);}
@Overrideprotected void onDestroy() {Destroy();//清楚webview缓存webView.clearCache(true);}
private void initView() {webView = (WebView) findViewById(R.id.webView);WebSettings settings = Settings();settings.setJavaScriptEnabled(true);settings.setBuiltInZoomControls(true);// 设置支持缩放settings.setSupportZoom(false);// 不支持缩放settings.setUseWideViewPort(false);// 将图片调整到适合webview大小settings.setLoadWithOverviewMode(true);// 缩放至屏幕的大小settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//支持缓存}

WebSettings 的常用方法介绍:

setJavaScriptEnabled(true);  //支持jssetPluginsEnabled(true);  //支持插件 setUseWideViewPort(false);  //将图片调整到适合webview的大小 setSupportZoom(true);  //支持缩放 setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局  supportMultipleWindows();  //多窗口 setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //关闭webview中缓存 setAllowFileAccess(true);  //设置可以访问文件 setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点webview webSettings.setBuiltInZoomControls(true); //设置支持缩放 setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 setLoadWithOverviewMode(true); // 缩放至屏幕的大小setLoadsImagesAutomatically(true);  //支持自动加载图片

WebViewClient 的方法全解:

doUpdateVisitedHistory(WebView view, String url, boolean isReload)  //(更新历史记录) 
onFormResubmission(WebView view, Message dontResend, Message resend) //(应用程序重新请求网页数据) 
onLoadResource(WebView view, String url) // 在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。 
onPageStarted(WebView view, String url, Bitmap favicon) //这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。 
onPageFinished(WebView view, String url) //在页面加载结束时调用。同样道理,我们知道一个页面载入完成,于是我们可以关闭loading 条,切换程序动作。 
onReceivedError(WebView view, int errorCode, String description, String failingUrl)// (报告错误信息) 
onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm)//(获取返回信息授权请求) 
onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) //重写此方法可以让webview处理https请求。
onScaleChanged(WebView view, float oldScale, float newScale) // (WebView发生改变时调用) 
onUnhandledKeyEvent(WebView view, KeyEvent event) //(Key事件未被加载时调用) 
shouldOverrideKeyEvent(WebView view, KeyEvent event)//重写此方法才能够处理在浏览器中的按键事件。 
shouldOverrideUrlLoading(WebView view, String url) 
//在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。

关于WebView加载的H5,H5中视频播放加载失败的问题解决:

1、l中 在webview所在的activity配置文件加入下面属性android:hardwareAccelerated="true"2、添加 webSettings.setPluginState(WebSettings.PluginState.ON);没加的话,视频会加载失败 3、5.0 以上的手机要加这个判断if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {webSettings.setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);}

本文发布于:2024-02-04 22:42:38,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170718030560364.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:视频播放   加载   Android   WebView   url
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23