Android webView 缓存 Cache + HTML5离线功能 解决

摘要:
数据缓存分为两种:AppCache和DOMStorage。其大小目前通常是5M。在Android上需要手动开启,并设置路径和容量Android中Webkit使用一个db文件来保存AppCache数据如果需要存储一些简单的用key/value对即可解决的数据,DOMStorage是非常完美的方案。近来工作中也要用到HTML5离线应用功能,由于是在Android平台上做,所以自然而然的选择Webview来解析网页。但如何使Webivew支持HTML5离线应用功能呢,经过反复摸索和上网查找资料,反复做试验终于成功了。
时间 2013-06-11 21:06:14CSDN博客
原文  http://blog.csdn.net/moubenmao/article/details/9076917
主题 Android HTML5
            WebView的缓存可以分为页面缓存和数据缓存。 
           页面缓存是指加载一个网页时的html、JS、CSS等页面或者资源数据。这些缓存资源是由于浏览器的行为而产生,开发者只能通过配置HTTP响应头影响浏览器的行为才能间接地影响到这些缓存数据。
         他们的索引存放在/data/data/package_name/databases下。他们的文件存放在/data/data/package_name/cache/xxxwebviewcachexxx下。文件夹的名字在2.x和4.x上有所不同,但都文件夹名字中都包含webviewcache。
            数据缓存分为两种:AppCache和DOM Storage(Web Storage)。他们是因为页面开发者的直接行为而产生。所有的缓存数据都由开发者直接完全地掌控。 
AppCache使我们能够有选择的缓冲web浏览器中所有的东西,从页面、图片到脚本、css等等。尤其在涉及到应用于网站的多个页面上的CSS和JavaScript文件的时候非常有用。其大小目前通常是5M。 
            在Android上需要手动开启(setAppCacheEnabled),并设置路径(setAppCachePath)和容量(setAppCacheMaxSize) 
Android中Webkit使用一个db文件来保存AppCache数据(my_path/ApplicationCache.db)
          如果需要存储一些简单的用key/value对即可解决的数据,DOM Storage是非常完美的方案。根据作用范围的不同,有Session Storage和Local Storage两种,分别用于会话级别的存储(页面关闭即消失)和本地化存储(除非主动删除,否则数据永远不会过期)。 
在Android中可以手动开启DOM Storage(setDomStorageEnabled),设置存储路径(setDatabasePath) 
Android中Webkit会为DOM Storage产生两个文件(my_path/localstorage/http_h5.m.taobao.com_0.localstorage和my_path/localstorage/Databases.db)
           另外,在Android中清除缓存时,如果需要清除Local Storage的话,仅仅删除Local Storage的本地存储文件是不够的,内存里面有缓存数据。如果再次进入页面,Local Storage中的缓存数据同样存在。需要杀死程序运行的当前进程再重新启动才可以。 
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
HTML5的离线应用功能可以使得WebApp即使在网络断开的情况下仍能正常使用,这是个非常有用的功能。近来工作中也要用到HTML5离线应用功能,由于是在Android平台上做,所以自然而然的选择Webview来解析网页。但如何使Webivew支持HTML5离线应用功能呢,经过反复摸索和上网查找资料,反复做试验终于成功了。 
首先需配置webview的的一些属性,假设activity中已经有了一个Webview的实例对象,名为m_webview,然后增加以下代码: 
[html] view plain copy
WebSettings  webseting  =m_webview .getSettings();  
    webseting.setDomStorageEnabled(true);             
        webseting.setAppCacheMaxSize(1024*1024*8);//设置缓冲大小,我设的是8M  
    String  appCacheDir  =  this .getApplicationContext().getDir("cache", Context.MODE_PRIVATE).getPath();      
        webseting.setAppCachePath(appCacheDir);  
        webseting.setAllowFileAccess(true);  
        webseting.setAppCacheEnabled(true);  
        webseting.setCacheMode(WebSettings.LOAD_DEFAULT);   
webview可以设置一个WebChromeClient对象,在其onReachedMaxAppCacheSize函数对扩充缓冲做出响应。代码如下: 
[html] view plain copy
m_webview.setWebChromeClient(m_chromeClient);  
    private WebChromeClient  m_chromeClient  =  newWebChromeClient(){  
        //扩充缓存的容量    
@Override  
    public void onReachedMaxAppCacheSize(longspaceNeeded,    
                longtotalUsedQuota, WebStorage.QuotaUpdater quotaUpdater) {    
            quotaUpdater.updateQuota(spaceNeeded * 2);    
        }         
    };  
其次要修改http服务器中的配置,使其支持text/cache-manifest,我使用的是apache服务器,是windows版本的,在apache的conf文件夹中找到mime.types文件,打开后在文件的最后加上 
“text/cache-manifest              
经过以上设置Webview就可以支持HTML5的离线应用了。 
附录链接1中说缓冲目录应该是getApplicationContext().getCacheDir().getAbsolutePath();但我经过试验后发现设置那个目录不起作用,可能是Android版本不同吧,我的是Android4.0.3,而他的可能是以前的Android版本吧。 
缓冲目录使用  
      getApplicationContext().getDir("cache", Context.MODE_PRIVATE).getPath()是从附录链接2中找到的线索。
      附录链接:
      1.
      http://alex.tapmania.org/2010/11/html5-cache-android-webview.html
      2.
      http://johncookie.iteye.com/blog/1182459
      3.HTML5 Offline官方文档:
      http://www.w3.org/TR/html5/offline.html#manifests

原因: 
webview加载 服务端的网页,为了减少访问压力,用html5缓存技术,本地建了数据库,在手机浏览器里  可以显示页面,换成webView就不行了。 
解决范例: 
Activity code: 
?
代码片段,双击复制
01
public classefan_NewsReader extends Activity {
        /** Called when the activity is first created. */
        @Override
        public voidonCreate(Bundle savedInstanceState)
        {   
                super .onCreate(savedInstanceState);   
                setContentView(R.layout.main);            
                WebView myWebView=(WebView)findViewById(R.id.my_webview);   
                myWebView.setWebViewClient( newWebViewClient());   
                WebSettings settings =myWebView.getSettings();
                //开启javascript设置
                settings.setJavaScriptEnabled( true);  
                //设置可以使用localStorage
                settings.setDomStorageEnabled( true);
                //应用可以有数据库
                settings.setDatabaseEnabled( true);   
                String dbPath = this .getApplicationContest().getDir( "database", Context.MODE_PRIVATE).getPath();
                settings.setDatabasePath(dbPath);
                //应用可以有缓存
                settings.setAppCacheEnabled( true);            
                String appCaceDir = this .getApplicationContext().getDir( "cache", Context.MODE_PRIVATE).getPath();
                settings.setAppCachePath(appCaceDir);
                myWebView.loadUrl( "http://10.10.35.47:8080/html5test/test.htm");
        }
}
HTML5 page source code: 
?
代码片段,双击复制

    < html manifest = "mymanifest.manifest" >
    < head >
< meta http-equiv = "Content-Type" content = "text/html; content=" no-cache"charset = utf -8" />
< script type = "text/javascript" src = "js/jquery-1.6.1.min.js" ></ script >
< script >
$(document).ready(function(){      
    databaseTest();
});
function databaseTest(){
    //open database
      var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);  
       db.transaction(function (tx) {            
       tx.executeSql('CREATE TABLE IF NOT EXISTS testHtml (id unique, contentText)');
       tx.executeSql('INSERT INTO testHtml (contentText) VALUES ("insert data test!")');  
       });  
      db.transaction(function(tx){           
      tx.executeSql('SELECT * FROM testHtml',[],function(tx,result){
             var len=result.rows.length;
             var msg = "< p >Found rows: " + len + "</ p >";  
             $("#testinfo").append(msg);
         },null);
      });   
}
</ script >
</ head >
< body >
    < div >here is test info:</ div >
    < div id = "testinfo" ></ div >
</ body >
其他设置还有: 
settings.setCacheMode(WebSettings.LOAD_DEFAULT);   //默认使用缓存 
settings.setAppCacheMaxSize(8*1024*1024);   //缓存最多可以有8M 
settings.setAllowFileAccess(true);   //可以读取文件缓存(manifest生效) 
inWebChromeClient : 
?
代码片段,双击复制

10
myWebView.setWebChromeClient( newWebChromeClient()
{   
        @Override    
        public voidonExceededDatabaseQuota(String url, String databaseIdentifier,
                        long currentQuota, long estimatedSize, longtotalUsedQuota,
                        WebStorage.QuotaUpdater quotaUpdater)   
        {        
                quotaUpdater.updateQuota(estimatedSize * 2);   
        }
}
or: 
?
代码片段,双击复制

10
myWebView.setWebChromeClient( newWebChromeClient()
{
    //扩充缓存的容量   
@Override    
        public void onReachedMaxAppCacheSize( long spaceNeeded, longtotalUsedQuota,
                        WebStorage.QuotaUpdater quotaUpdater)   
        {        
                quotaUpdater.updateQuota(spaceNeeded * 2);
    }
}
按照范例,我成功的解决了我的问题,而且之前弹出框所出现的找不到数据(提示:underfine)也解决了,这个应该是当初数据库没设所引起的。 

免责声明:文章转载自《Android webView 缓存 Cache + HTML5离线功能 解决》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇mysql 禁用查询缓存 query cacheMac-VM迁移注意事项下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

用HTML5里的window.postMessage在两个网页间传递数据

说明 window.postMessage()方法可以安全地实现Window对象之间的跨域通信。例如,在一个页面和它生成的弹出窗口之间,或者是页面和嵌入其中的iframe之间。 通常情况下,不同页面上的脚本允许彼此访问,当且仅当它们源自的页面共享相同的协议,端口号和主机(也称为“同源策略”)。window.postMessage()提供了一个受控的机制来...

四、使用ADB命令清除缓存

一、ADB Shell 应用 查看目录结构 :adb shell ls 查看系统当前日期 :adb shell date 查看系统 CPU 使用情况 :adb shell cat /proc/cpuinfo 查看系统内存使用情况 :adb shell cat /proc/meminfo 显示所有应用 :adb shell pm list pack...

什么是缓存

缓存是数据交换的缓冲区(Cache):当某一硬件要读取数据时,首先会从缓存中查找需要的数据,如果找到了则直接执行,找不到的话,则从内存中找。(所以,缓存与内存的读取级别相同,优先级优于内存) 缓存的作用就是帮助硬件更快地运行:因为缓存的运行速度比内存快很多。   缓存的硬件原理:缓存通常时候的是RAM(断电即掉的非永久储存) 缓存在使用完成后会将文件送到硬盘...

nodeJS从入门到进阶一(基础部分)

一、Node.js基础知识 1、概念 简单的说 Node.js 就是运行在服务端的 JavaScript。 Node.js 是JavaScript的运行环境 Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。 2、安装使用 官网下载地址:http://nodejs.cn/ nodeJS5个基本对象: 1、require 引...

HTML5和CSS3基础

第一章 Web时间代的变迁一、HTML4常见用div来划分页面结构方法,HTML5新出现的更语义化的标签. 二、可以放心使用HTML5的三个理由   1、兼容性:HTML5在老版本的浏览器也可以正常运行   2、实用性:HTML5内部并没有封装什么很复杂的功能,只封装了简单实用的功能   3、非革命性的发展:HTML5的内部功能不是革命性,而是发展性的...

Nginx 用最快方式让缓存失效

103 一般让及时缓存失效针对nginx官方是收费的 我们可以用第三方模块 https://github.com/FRiCKLE/ngx_cache_purge proxy_cache_path /data/nginx/tmpcache levels=2:2 keys_zone=two:10m loader_threshold=300...