2024年最全WebView的使用及实战,前端面试简历包装

总结
  • 对于框架原理只能说个大概,真的深入某一部分具体的代码和实现方式就只能写出一个框架,许多细节注意不到。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 算法方面还是很薄弱,好在面试官都很和蔼可亲,擅长发现人的美哈哈哈…(最好多刷一刷,不然影响你的工资和成功率???)

  • 在投递简历之前,最好通过各种渠道找到公司内部的人,先提前了解业务,也可以帮助后期优秀 offer 的决策。

  • 要勇于说不,对于某些 offer 待遇不满意、业务不喜欢,应该相信自己,不要因为当下没有更好的 offer 而投降,一份工作短则一年长则 N 年,为了幸福生活要慎重选择!!!

第一次跳槽十分忐忑不安,和没毕业的时候开始找工作是一样的感受,真的要相信自己,有条不紊的进行。如果有我能帮忙的地方欢迎随时找我,比如简历修改、内推、最起码,可以把烦心事说一说,人嘛都会有苦恼的~

祝大家都有美好的未来,拿下满意的 offer。

settings.setCacheMode(WebSettings.LOAD_DEFAULT);


webView请求错误时候的处理


因为系统自带的 错误页面太丑了,所以我们经常会对其 进行处理,目前本人了解到的主要有两种方法

- 加载本地的控件,显示 错误信息

- 加载自己 定义的 html页面

加载本地的控件

@SuppressWarnings(“deprecation”)

@Override

public void onReceivedError(WebView view, int errorCode, String description, String

failingUrl) {

super.onReceivedError(view, errorCode, description, failingUrl);

if (errorCode == 404) {

//用javascript隐藏系统定义的404页面信息

//String data = “Page NO FOUND!”;

// view.loadUrl(“javascript:document.body.innerHTML=”" + data + “”");

mWebView.setVisibility(View.INVISIBLE);

mErrorView.setVisibility(View.VISIBLE);

}

}

加载 定义的 html页面

@SuppressWarnings(“deprecation”)

@Override

public void onReceivedError(WebView view, int errorCode, String description, String

failingUrl) {

super.onReceivedError(view, errorCode, description, failingUrl);

if (errorCode == 404) {

//用javascript隐藏系统定义的404页面信息

String data = “Page NO FOUND!”;

view.loadUrl(“javascript:document.body.innerHTML=”" + data + “”");

}

}

当然实际开发中为了给用户比较还要的体验,会做非常多的处理,包括有网络情况和没有网络情况的处理,对于没有网络情况的处理,这里我们跳转到打开WiFi界面,详情可以参照我的 上一篇博客android 监听网络状态的变化及实战,而对于有网络情况的处理,这里我们只处理404错误,其他错误请根据项目的需求自行处理。

@SuppressWarnings(“deprecation”)

@Override

public void onReceivedError(WebView view, int errorCode, String description, String

failingUrl) {

super.onReceivedError(view, errorCode, description, failingUrl);

// 没有网络连接

if (false == APP.getInstance().isConnected()) {

APP.getInstance().showWifiDlg(NewsDetailActivity.this);

} else {

if (errorCode == 404) {

//用javascript隐藏系统定义的404页面信息

String data = “Page NO FOUND!”;

view.loadUrl(“javascript:document.body.innerHTML=”" + data + “”");

mWebView.setVisibility(View.INVISIBLE);

} else {//其他状态码错误的处理,这里就不罗列出来了

}

}

}


webView cookie的同步与清除


关于这个问题,我们主要分为两步,

- 怎样获取cookie

- 怎样将cookie与webView进行 同步

对于怎样获取 cookie,主要有以下方法

下面只给出核心代码

第一,使用DefaultHttpClient

DefaultHttpClient client = new DefaultHttpClient();

CookieStore store = client.getCookieStore();

List list = store.getCookies();

第二,使用HttpURLConnection

URLConnection con= (HttpURLConnection) url.openConnection();

// 取得sessionid.

String cookieval = con.getHeaderField(“set-cookie”);

String sessionid;

if(cookieval != null) {

sessionid = cookieval.substring(0, cookieval.indexOf(“;”));

}

发送设置cookie:

URL url = new URL(requrl);

HttpURLConnectioncon= (HttpURLConnection) url.openConnection();

if(sessionid != null) {

con.setRequestProperty(“cookie”, sessionid);

}

第三,使用Retrofit

Call call = tnGouAPi.getTest(test);

call.enqueue(new Callback() {

@Override

public void onResponse(Call call, Response response) {

ResponseBody body = response.body();

Headers headers = response.headers();

Set names = headers.names();

for(String key:names){

String value = headers.get(key);

}

try {

Logger.i(“onResponse: body=” + body.string());

} catch (IOException e) {

e.printStackTrace();

}

}

@Override

public void onFailure(Call call, Throwable t) {

Logger.i(“onResponse: t=” + t.getMessage());

}

});

cookie 同步

/**

  • cookie同步

*/

@SuppressWarnings(“deprecation”)

private void syncCookieToWebView(String url,List cookies)

{

CookieSyncManager.createInstance(this);

CookieManager cm = CookieManager.getInstance();

cm.setAcceptCookie(true);

if(cookies!=null)

{

for (String cookie : cookies)

{

cm.setCookie(url,cookie);//注意端口号和域名,这种方式可以同步所有cookie,包括sessionid

}

}

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

CookieManager.getInstance().flush();

} else {

CookieSyncManager.getInstance().sync();

}

}

清除cookie

@SuppressWarnings(“deprecation”)

public void clearCookies(Context context) {

CookieSyncManager.createInstance(context);

CookieManager cookieManager = CookieManager.getInstance();

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

cookieManager.removeAllCookies(null);

} else {

cookieManager.removeAllCookie();

}

}

注意事项

  1. 同步cookie要在WebView加载url之前,否则WebView无法获得相应的cookie,也就无法通过验证。

  2. 每次登录成功后都需要调用”syncCookie”方法将cookie同步到WebView中,同时也达到了更新WebView的cookie。如果登录后没有及时将cookie同步到WebView可能导致WebView拿的是旧的session id和服务器进行通信。


webView 下载文件的两种方法


总共 有两种 方法,

- 第一种,自己实现实现逻辑 ,下载,保存到相应目录;

- 第二种,调用系统的下载方法

核心代码如下

主要是给webView设置DownloadListener监听器

mWebView.setDownloadListener(new DownloadListener() {

@Override

public void onDownloadStart(String url, String userAgent, String contentDisposition,

String mimetype, long contentLength) {

//第一种下载方式是 自定义的http工具类

// new HttpDownloadThread(url,contentDisposition,mimetype,contentLength).start();

//第二种下载方式是调用系统的webView,具有默认的进度条

Intent intent = new Intent(Intent.ACTION_VIEW);

intent.setData(Uri.parse(url));

startActivity(intent);

}

});

HttpDownloadThread

public class HttpDownloadThread extends Thread {

private String mUrl;

private String mContentDisposition;

private String mMimetype;

private long mContentLength;

public HttpDownloadThread(String url, String contentDisposition, String mimetype, long contentLength) {

this.mUrl = url;

this.mContentDisposition=contentDisposition;

this.mContentDisposition=mimetype;

this.mContentDisposition=contentDisposition;

}

@Override

public void run() {

URL url;

try {

url = new URL(mUrl);

HttpURLConnection conn = (HttpURLConnection) url.openConnection();

conn.setDoInput(true);

conn.setDoOutput(true);

InputStream in = conn.getInputStream();

File downloadFile;

File sdFile;

FileOutputStream out = null;

if(Environment.getExternalStorageState().equals(Environment.MEDIA_UNMOUNTED)){

downloadFile = Environment.getExternalStorageDirectory();

sdFile = new File(downloadFile, “test.file”);

out = new FileOutputStream(sdFile);

}

//buffer 4k

byte[] buffer = new byte[1024 * 4];

int len = 0;

while((len = in.read(buffer)) != -1){

if(out != null)

out.write(buffer, 0, len);

}

//close resource

if(out != null)

out.close();

if(in != null){

in.close();

}

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}


webView的 一些扩展使用


// 设置是否支持画面缩放

settings.setBuiltInZoomControls(true);

settings.setSupportZoom(true);

// 设置是否显示缩放器

settings.setDisplayZoomControls(false);

// 设置字体的大小

settings.setTextZoom(120);

关于webView 与js互相调用的,可以 参考这一篇文章webview与javascript交互回调与异步


题外话


  • 个人觉得webView还是 挺坑爹的,在不同的sdk版本中,方法修改的幅度有点多,看文档的时候经常看到许多方法过时了

  • webView的用法还有很多很多,这里只讲解了比较常用的,有兴趣的话了解更多的 话,请自行 阅读官方文档。不过本人建议是先掌握常用的 就OK了,以后其他需要用到的再去学就好了


总结
  • 对于框架原理只能说个大概,真的深入某一部分具体的代码和实现方式就只能写出一个框架,许多细节注意不到。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 算法方面还是很薄弱,好在面试官都很和蔼可亲,擅长发现人的美哈哈哈…(最好多刷一刷,不然影响你的工资和成功率???)

  • 在投递简历之前,最好通过各种渠道找到公司内部的人,先提前了解业务,也可以帮助后期优秀 offer 的决策。

  • 要勇于说不,对于某些 offer 待遇不满意、业务不喜欢,应该相信自己,不要因为当下没有更好的 offer 而投降,一份工作短则一年长则 N 年,为了幸福生活要慎重选择!!!

第一次跳槽十分忐忑不安,和没毕业的时候开始找工作是一样的感受,真的要相信自己,有条不紊的进行。如果有我能帮忙的地方欢迎随时找我,比如简历修改、内推、最起码,可以把烦心事说一说,人嘛都会有苦恼的~

祝大家都有美好的未来,拿下满意的 offer。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值