WebView中存在著兩種緩衝:網頁資料緩衝(儲存開啟過的頁面及資源)、H5緩衝(即appcache)。 一、網頁緩衝 1、緩衝構成/data/data/package_name/cache//data/data/package_name/database/webview.db/data/data/package_name/database/webviewCache.db 2、緩衝模式較難理解的是以下兩個模式:LOAD_DEFAULT,根據cache-control決定是否從網路上取資料。LOAD_CACHE_ELSE_NETWORK,只要本地有,無論是否到期,或者no-cache,都使用緩衝中的資料。如:m.taobao.com的cache-control為no-cache,在模式LOAD_DEFAULT下,無論如何都會從網路上取資料,如果沒有網路,就會出現錯誤頁面;在LOAD_CACHE_ELSE_NETWORK模式下,無論是否有網路,只要開啟過一次,都使用緩衝。m.sina.com.cn的cache-control為max-age=60,在兩種模式下都使用本機快取資料。 總結:根據以上兩種模式,建議緩衝策略為,判斷是否有網路,有的話,使用LOAD_DEFAULT,無網路時,使用LOAD_CACHE_ELSE_NETWORK。 3、清除緩衝clearCache(boolean)。CacheManager.clear。高版本中需要調用隱藏API。 4、控制大小無系統API支援。可選方式:定時統計緩衝大小、按時間順序刪除緩衝。 二、H5緩衝 1、緩衝構成根據setAppCachePath(String appCachePath)提供的路徑,在H5使用緩衝過程中產生的快取檔案。 2、緩衝模式無模式選擇,通過setAppCacheEnabled(boolean flag)設定是否開啟。預設關閉,即,H5的緩衝無法使用。 3、清除緩衝找到調用setAppCachePath(String appCachePath)設定緩衝的路徑,把它下面的檔案全部刪除就OK了。 4、控制大小通過setAppCacheMaxSize(long appCacheMaxSize)設定緩衝最大容量,預設為Max Integer。同時,可能通過覆蓋WebChromeClient.onReachedMaxAppCacheSize(long requiredStorage, long quota, WebStorage.QuotaUpdater quotaUpdater)來設定緩衝超過先前設定的最大容量時的策略。 三、參考網址 以下地址有關於H5緩衝的一些內幕,如每個Application只調用一次WebSettings.setAppCachePath(),WebSettings.setAppCacheMaxSize()被忽略等一系列問題,需要仔細閱讀和實驗。http://code.google.com/p/android/issues/detail?id=24180