安卓网页离线保存_Android webView 缓存 Cache + 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(){//扩充缓存的容量
@Overridepublic 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.*/@Overridepublic 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 :?代码片段,双击复制
10myWebView.setWebChromeClient(newWebChromeClient()
{
@Overridepublic voidonExceededDatabaseQuota(String url, String databaseIdentifier,long currentQuota, long estimatedSize, longtotalUsedQuota,
WebStorage.QuotaUpdater quotaUpdater)
{
quotaUpdater.updateQuota(estimatedSize* 2);
}
}
or:?代码片段,双击复制
10myWebView.setWebChromeClient(newWebChromeClient()
{//扩充缓存的容量
@Overridepublic void onReachedMaxAppCacheSize( long spaceNeeded, longtotalUsedQuota,
WebStorage.QuotaUpdater quotaUpdater)
{
quotaUpdater.updateQuota(spaceNeeded* 2);
}
}
按照范例,我成功的解决了我的问题,而且之前弹出框所出现的找不到数据(提示:underfine)也解决了,这个应该是当初数据库没设所引起的。
安卓网页离线保存_Android webView 缓存 Cache + HTML5离线功能 解决相关推荐
- Android webView 缓存 Cache + HTML5离线功能 解决
WebView中存在着两种缓存:网页数据缓存(存储打开过的页面及资源).H5缓存(即appcache). 一.网页缓存 1.缓存构成 /data/data/package_name/cache/ /d ...
- 安卓网页广告拦截_Android webview广告过滤的实现
现在大部分的android平台的浏览器都具有广告过滤的功能,同时大部分网站都有广告.广告行业是个盈利巨大的产业,就我看来,现在绝大部分的互联网产品,一般有两种营利模式:免费有广告和会员无广告:他们大部 ...
- adb 安卓模拟器 进程端口_Android模拟器端口被占用问题的解决办法
一.问题描述 今天在Eclipse中运行Android项目时遇到"The connection to adb is down, and a severe error has occured& ...
- html5 离线资源缓存,html5的离线缓存使用方法
html5的离线缓存使用方法 发布时间:2020-06-15 10:51:01 来源:亿速云 阅读:109 作者:Leah 这篇文章将为大家详细讲解有关html5的离线缓存使用方法,小编觉得挺实用的, ...
- 神奇的HTML5离线存储(应用程序缓存)
声明:本文为原创文章,如需转载,请注明来源并保留原文链接前端小尚,谢谢! 前言 使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本. HTML5引入 ...
- Webview离线功能(优先cache缓存+cache缓存管理)
在做Webview显示服务器的html功能时 需要加入离线功能. 开始思路很狭隘,以为一定应该是从服务器得到的html文件,下载到本地后加载~ 但是这样不能离线查看图片,因为图片数据并不再html中, ...
- android网页离线保存
众里寻他千百度,蓦然回首,那人却在灯火阑珊处. 众里寻他 将网页保存为离线mht文件,没有找到第三方开源库,网上的例子: http://blog.csdn.net/dongle2001/article ...
- android设置webview缓存目录,Android基础入门教程——7.5.5 WebView缓存问题
Android基础入门教程--7.5.5 WebView缓存问题 Android基础入门教程 本节引言:现在很多门户类信息网站,比如虎嗅,ifanr,钛媒体等等的APP,简单点说是信息阅读类的APP, ...
- html5 客户端数据缓存机制,深入理解HTML5离线缓存机制
TML5提供了一种离线应用缓存机制,使得网页应用可以离线使用,这种机制在移动端浏览器上支持度非常广,所有版本的android和ios浏览器都能很好的支持.我们可以放心的使用该特性来加速移动端页面的访问 ...
- asp.net 应用数据缓存 -- Cache对象使用
ASP.NET 应用数据缓存 -- Cache对象使用 [原文:http://msdn.microsoft.com/zh-cn/library/18c1wd61%28v=vs.100%29.aspx] ...
最新文章
- JavaScript 设计模式的七大原则(未完成)
- 将HTMLCollection转换为数组的最有效方法
- oracle SQL 命令行(三.增删改查)
- python爬虫requests-Python爬虫(三)Requests库
- 生产上第一使用线程池后的总结与反思
- 倾斜模型精细化处理_广州智迅诚单体化实景三维模型为智慧城市提供了平台数据基础...
- OpenMP之双重for循环并行计算改进
- 如何进行有效的沟通----日常沟通及会议
- 并发编程中,你加的锁未必安全
- jsp 页面实现增减行
- Eclipse启动时指定jdk版本
- CSS content 属性 CSS counter-increment 属性 CSS counter-reset 属性
- 跨站脚本攻击(反射型xss)笔记(一)
- easyui框架的使用,定制日历控件
- 【Proteus仿真】集成运算放大器搭建以及基本功能电路
- java软尾山地车评测_如何挑选适合自己的软尾山地自行车
- 贸易进出口管理-报关单管理
- [从头读历史] 第248节 先天八卦和后天八卦
- ubantu 安装jekins
- 上汽集团 java_【上汽集团工资】研发工程师待遇-看准网
热门文章
- GPS NAME0183 详解
- 计算机模拟数学建模,计算机模拟数学建模
- Android Jetpack组件之App Startup,源码+原理+手写框架
- 系统调用 操作系统课程设计 Linux内核编译 centos Ubuntu
- 雷电模拟器7抓包安装证书
- 2022年Java面试宝典【4万字带答案】
- P-SIF长文本表示方法
- 如何阅读Java源码 阅读java的真实体会
- ztek usb转串口 linux,Z-tek驱动下载_Z-tek usb转串口驱动官方下载 - 系统之家
- mysql2008怎么安装_SQL Server 2008如何安装及附加数据库?