Android webView缓存机制

转自:http://www.eoeandroid.com/thread-190311-1-1.html

在项目中经常会使用到WebView控件,当加载html页面时,会在/data/data/应用package目录下生成database与cache两个文件夹如下图如示:

请求的url记录是保存在webviewCache.db,而url的内容是保存在webviewCache文件夹下.


为了便于理解,接下来模拟一个案例,定义一个html文件,在里面显示一张图片,用WebView加载出来,然后再试着从缓存里把这张图片读取出来并显示。


第一步:新建一个Android工程命名为WebViewCache.目录结构如下:



第二步:在assets目录下新建一个html文件,命名为index.html
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" >
<html>
   <head>
    <title>WebViewCacheDemo</title>
     
    <meta http-equiv= "keywords" content= "keyword1,keyword2,keyword3" >
    <meta http-equiv= "description" content= "this is my page" >
    <meta http-equiv= "content-type" content= "text/html; charset=UTF-8" >
     
   </head>
   
   <body>
      <img src= "http://img04.taobaocdn.com/imgextra/i4/608825099/T2nGXBXXpaXXXXXXXX_!!608825099.jpg_310x310.jpg" />
   </body>
</html>


第三步:修改main.xml布局文件,一个WebView控件一个Button(点击加载缓存图片用),代码如下:
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
<?xml version= "1.0" encoding= "utf-8" ?>
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android"
    android:orientation= "vertical" android:layout_width= "fill_parent"
    android:layout_height= "fill_parent" >
    <WebView android:layout_width= "fill_parent"
         android:layout_height= "wrap_content"
         android:id= "@+id/webView" />
    <Button android:layout_width= "wrap_content"
         android:layout_height= "wrap_content"
         android:layout_gravity= "center_horizontal"
         android:text= "从缓存读取图片"
         android:id= "@+id/button" />
</LinearLayout>

第四步:修改主核心程序WebViewCacheDemo.java,这里我只加载了index.html文件,按钮事件暂时没写,代码如下:
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
package com.ljq.activity;
 
import java.io.File;
import java.io.FileInputStream;
 
import android.app.Activity;
import android.app.Dialog;
import android.app.AlertDialog.Builder;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.ImageView;
 
public class WebViewActivity extends Activity {
    private WebView webView;
    private static final String url= "file:///android_asset/index.html" ;
     
    @Override
    public void onCreate(Bundle savedInstanceState) {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.main);
         
         webView=(WebView)findViewById(R.id.webView);
         webView.loadUrl(url);
    }
}

第五步:在AndroidMainifest.xml文件中加访问网络的权限:
?
代码片段,双击复制
01
<uses-permission android:name= "android.permission.INTERNET" />

运行效果如下:

此时我们在WebViewCache.db里的cache.table里多了一条记录如下图所示:

在cache/webviewCache/目录下多了一个10d8d5cd文件,刚好和cache.table里的filepath,我们可以断定这个文件就是我们从网上拽下来的图片:


为了验证猜想,我给Button增加事件响应,就是弹出Dialog,里面加载缓存的图片,完整代码如下:
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package com.ljq.activity;
 
import java.io.File;
import java.io.FileInputStream;
 
import android.app.Activity;
import android.app.Dialog;
import android.app.AlertDialog.Builder;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.ImageView;
 
public class WebViewActivity extends Activity {
    private WebView webView;
    private static final String url= "file:///android_asset/index.html" ;
     
    @Override
    public void onCreate(Bundle savedInstanceState) {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.main);
         
         webView=(WebView)findViewById(R.id.webView);
         webView.loadUrl(url);
         
         //点击按钮时弹出对话框
         Button button=(Button)findViewById(R.id.button);
         button.setOnClickListener( new View.OnClickListener() {
         
             public void onClick(View v) {
                ImageView imageView= new ImageView(WebViewActivity. this );
                imageView.setImageBitmap(getPictureFromCache());
                Builder builder= new android.app.AlertDialog.Builder(WebViewActivity. this );
                //设置对话框的图标
                builder.setTitle( "从缓存查看图片" );
                builder.setView(imageView);
                //退出按钮
                builder.setPositiveButton( "退  出" , new OnClickListener(){
 
                     public void onClick(DialogInterface dialog, int which) {
                         //关闭alert对话框架
                         dialog.cancel();
                     }
                     
                });
                builder.create().show();
             }
         
         });
    }
     
    /**
      * 从缓存获取图片
      *
      * @return
      */
    private Bitmap getPictureFromCache(){
         Bitmap bitmap= null ;
         try {
             //这里写死,在实际开发项目中要灵活使用
             File file= new File(getCacheDir()+ "/webviewCache/10d8d5cd" );
             FileInputStream inStream= new FileInputStream(file);
             bitmap=BitmapFactory.decodeStream(inStream);
         } catch (Exception e) {
             e.printStackTrace();
         }
         return bitmap;
    }
}

第六步:再次运行工程,点击button按钮,效果如下图所示:


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值