2024年最新Android-WebView的使用,安卓开发面试题8消息机制全解析全解析

总结:

各行各样都会淘汰一些能力差的,不仅仅是IT这个行业,所以,不要被程序猿是吃青春饭等等这类话题所吓倒,也不要觉得,找到一份工作,就享受安逸的生活,你在安逸的同时,别人正在奋力的向前跑,这样与别人的差距也就会越来越遥远,加油,希望,我们每一个人,成为更好的自己。

  • BAT大厂面试题、独家面试工具包,

  • 资料包括 数据结构、Kotlin、计算机网络、Framework源码、数据结构与算法、小程序、NDK、Flutter

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

1.WebView简介

=====================================================================

WebView 是一个用来显示 Web 网页的控件,继承自 AbsoluteLayout,和使用系统其他控件没什么区别,只是 WeView 控件方法比较多比较丰富。因为它就是一个微型浏览器,包含一个浏览器该有的基本功能,例如:滚动、缩放、前进、后退下一页、搜索、执行js等功能。

2.自行定制WebView类

========================================================================

除了直接WebView外我们还可以添加你自己的行为,可以自行定制下述类:

①WebChromeClient,辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等,比如下面这些方法

| 方法 | 作用 |

| — | — |

| onJsAlert(WebView view,String url,String message,JsResult result) | 处理Js中的Alert对话框 |

| onJsConfirm(WebView view,String url,String message,JsResult result) | 处理Js中的Confirm对话框 |

| onJsPrompt(WebView view,String url,String message,String defaultValue,JsPromptResult result) | 处理Js中的Prompt对话框 |

| onProgressChanged(WebView view,int newProgress) | 当加载进度条发生改变时调用 |

| onReceivedIcon(WebView view, Bitmap icon) | 获得网页的icon |

| onReceivedTitle(WebView view, String title) | 获得网页的标题 |

②WebViewClient:辅助WebView处理各种通知与请求事件,比如下面这些方法:

| 方法 | 作用 |

| — | — |

| onPageStared(WebView view,String url) | 通知主程序网页开始加载 |

| onPageFinished(WebView view,String url,Bitmap favicon) | 通知主程序,网页加载完毕 |

| doUpdateVisitedHistory(WebView view,String url,boolean isReload) | 更新历史记录 |

| onLoadResource(WebView view,String url) | 通知主程序WebView即将加载指定url的资源 |

| onScaleChanged(WebView view,float oldScale,float newScale) | ViewView的缩放发生改变时调用 |

| shouldOverrideKeyEvent(WebView view,KeyEvent event) | 控制webView是否处理按键时间,如果返回true,则WebView不处理,返回false则处理 |

| shouldOverrideUrlLoading(WebView view,String url) | 控制对新加载的Url的处理,返回true,说明主程序处理WebView不做处理,返回false意味着WebView会对其进行处理 |

| onReceivedError(WebView view,int errorCode,String description,String failingUrl) | 遇到不可恢复的错误信息时调用 |

③WebSettings:WebView相关配置的设置,比如setJavaScriptEnabled()设置是否允许JS脚本执行,部分方法如下:

| 方法 | 作用 |

| — | — |

| getSettings() | 返回一个WebSettings对象,用来控制WebView的属性设置 |

| loadUrl(String url) | 加载指定的Url |

| loadData(String data,String mimeType,String encoding) | 加载指定的Data到WebView中.使用"data:"作为标记头,该方法不能加载网络数据.其中mimeType为数据类型如:textml,image/jpeg. encoding为字符的编码方式 |

| loadDataWithBaseURL(String baseUrl, String data, String mimeType, String encoding, String historyUrl) | 比上面的loadData更加强大 |

| setWebViewClient(WebViewClient client) | 为WebView指定一个WebViewClient对象.WebViewClient可以辅助WebView处理各种通知,请求等事件 |

| setWebChromeClient(WebChromeClient client) | 为WebView指定一个WebChromeClient对象,WebChromeClient专门用来辅助WebView处理js的对话框,网站title,网站图标,加载进度条等 |

3.WebView的基本使用

========================================================================

(1)在AndroidManifest.xml中注册权限

(2)在layout文件中加入WebView控件

<WebView

android:id=“@+id/webView”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

/>

(3)使用loadUrl()函数,将页面载入到WebView

WebView myWebView = (WebView) findViewById(R.id.webView);

myWebView.loadUrl(“https://www.baidu.com”);

注:互联网文件用:webView.loadUrl(“https://www.baidu.com”);

本地文件用:webView.loadUrl(“file:///android_asset/XX.html”); 本地文件存放在:assets文件中

通过以上3步就可以完成WebView控件的基本使用。

在这里插入图片描述

注:也可以使用loadData()加载一段html

WebView myWebView = (WebView) findViewById(R.id.webView);

//构造未编码的html字符串,并用Base64编码,再调用loadData()方法

String unencodedHtml =

“<html><body>‘%23’ is the percent code for ‘#‘ </body></html>”;

String encodedHtml = Base64.encodeToString(unencodedHtml.getBytes(),

Base64.NO_PADDING);

myWebView.loadData(encodedHtml, “text/html”, “base64”);

在这里插入图片描述

| loadUrl() | loadData(data, “text/html”, “UTF-8”) |

| — | — |

| 直接显示网页内容(单独显示网络图片) | 用来加载URI格式的数据,不能通过网络来加载内容, 不能加载图片 |

| 一般不会出现乱码 | 经常会遇到乱码的问题 |

4.js注入

================================================================

(1)开启js注入

WebView myWebView = (WebView) findViewById(R.id.webView);

myWebView.getSettings().setJavaScriptEnabled(true);

(2)加载页面并设置页面加载结束时的方法,注意注入js字符串中的分号

myWebView.loadUrl(“http://jwgl.fjnu.edu.cn”);

myWebView.setWebViewClient(new WebViewClient() {

@Override

public void onPageFinished(WebView view, String url) {

view.loadUrl(“javascript:” +

“var username = document.getElementById(‘txtUserName’);” +

“username.value = 123012016029;” +

“window.alert(username);”);

}

});

通过以上2步就可以完成WebView控件的js注入,并设置id为txtUserName的输入框的值。

5.后退事件

================================================================

用WebView点链接看了很多页以后为了让WebView支持回退功能,需要覆盖Activity类的onKeyDown()方法,如果不做任何处理,点击系统回退键,整个浏览器会调用finish()而结束自身,而不是回退到上一页面,如果希望浏览的网页回退而不是退出浏览器,需要在当前Activity中处理并消费掉该 Back 事件

@Override

public boolean onKeyDown(int keyCode, KeyEvent event) {

if ((keyCode == KEYCODE_BACK) && myWebView.canGoBack()) {

myWebView.goBack();

return true;

}

return super.onKeyDown(keyCode, event);

}

6.网页缩放

================================================================

根据我们一般的习惯打开网页对于看不清楚的地方,我们喜欢双指来缩放网页,而WebView默认是不支持缩放的,需要我们自己手动来设置。

myWebView.getSettings().setUseWideViewPort(true);//设定支持viewport

myWebView.getSettings().setLoadWithOverviewMode(true); //自适应屏幕

myWebView.getSettings().setBuiltInZoomControls(true);

myWebView.getSettings().setDisplayZoomControls(false);

myWebView.getSettings().setSupportZoom(true);//设定支持缩放

7.Cookies的使用

======================================================================

(1)获取WebView的Cookie数据

用户输入账号密码后,点击登陆,用户要拿着这个Cookie去访问服务器提供的相关服务,我们可以把cookie的获取写到onPageFinsihed的方法中

@Override

public void onPageFinished(WebView view, String url) {

CookieManager cookieManager = CookieManager.getInstance();

String CookieStr = cookieManager.getCookie(url);

Log.e(“Cookie”, "Cookies = " + CookieStr);

super.onPageFinished(view, url);

最后

我见过很多技术leader在面试的时候,遇到处于迷茫期的大龄程序员,比面试官年龄都大。这些人有一些共同特征:可能工作了5、6年,还是每天重复给业务部门写代码,工作内容的重复性比较高,没有什么技术含量的工作。问到这些人的职业规划时,他们也没有太多想法。

其实30岁到40岁是一个人职业发展的黄金阶段,一定要在业务范围内的扩张,技术广度和深度提升上有自己的计划,才有助于在职业发展上有持续的发展路径,而不至于停滞不前。

不断奔跑,你就知道学习的意义所在!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

助于在职业发展上有持续的发展路径,而不至于停滞不前。

不断奔跑,你就知道学习的意义所在!

[外链图片转存中…(img-km7nmEhv-1715136620041)]

[外链图片转存中…(img-tqsmibkA-1715136620042)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 18
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android WebView 中,AppCache(Application Cache)是一种用于离线应用的缓存机制,它允许网页应用在离线状态下加载和使用资源。AppCache 使用一个描述文件(通常是 `manifest.appcache`)来指定要缓存的文件列表。 当 WebView 加载包含 AppCache 的网页时,它会解析 manifest.appcache 文件,并按照其中指定的文件列表下载和缓存相关资源。manifest.appcache 文件是一个简单的文本文件,其内容由以下几个部分组成: 1. CACHE MANIFEST:指示这是一个 AppCache 文件。 2. CACHE:列出需要缓存的文件列表。每行表示一个文件的路径,可以是相对路径或绝对路径。这些文件将被下载并存储在本地缓存中。 3. NETWORK:列出不会被缓存的文件列表。这些文件将始终从网络加载。 4. FALLBACK:指定离线状态下的备用资源。当某个文件无法从缓存中加载时,会尝试从 FALLBACK 中指定的资源进行替代。 示例 manifest.appcache 文件内容如下: ``` CACHE MANIFEST # Version: 1.0.0 CACHE: index.html styles.css script.js NETWORK: api.example.com FALLBACK: offline.html /offline.html ``` 上述示例中,index.html、styles.css 和 script.js 会被缓存,api.example.com 不会被缓存(每次都从网络加载),而 offline.html 将作为离线状态下的替代资源。 需要注意的是,AppCache 在 Android 4.4(KitKat)之后被废弃,推荐使用 Service Worker 和其他离线技术来替代。因此,在开发新的应用时,建议考虑使用更现代的离线方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值