アプリのキャッシュを使用してパフォーマンスを承認しようとしています。
私は様々な場所で案内されてきました。(例: http: //xguru.net/621 ...)
cache.manファイルを作成し、mime-typeをtext/cache-manifestとして設定します。
問題は...
Google Chromeブラウザーではうまく機能しますが、私のAndroidフォンでは機能しません。
ICSとジンジャーブレッドでテストしました。
これはマニフェストファイルです。
CACHE MANIFEST
# manifest version v0.1
CACHE:
./programs.png
./video.png
NETWORK:
*
次に、Webビューをこのように設定します。
getSettings().setAppCacheEnabled(true);
getSettings().setDomStorageEnabled(true);
getSettings().setPluginsEnabled(true);
getSettings().setCacheMode(WebSettings.LOAD_DEFAULT);
(cacheModeをLOAD_NORMAL、NO_CACHEに変更しましたが、違いはありません。)
キャッシュの状態を確認するには、このサイトを使用します。 http://jonathanstark.com/blog/2009/09/27/debugging-html-5-offline-application-cache/
var cacheStatusValues = [];
cacheStatusValues[0] = 'uncached';
cacheStatusValues[1] = 'idle';
cacheStatusValues[2] = 'checking';
cacheStatusValues[3] = 'downloading';
cacheStatusValues[4] = 'updateready';
cacheStatusValues[5] = 'obsolete';
var cache = window.applicationCache;
cache.addEventListener('cached', logEvent, false);
cache.addEventListener('checking', logEvent, false);
cache.addEventListener('downloading', logEvent, false);
cache.addEventListener('error', logEvent, false);
cache.addEventListener('noupdate', logEvent, false);
cache.addEventListener('obsolete', logEvent, false);
cache.addEventListener('progress', logEvent, false);
cache.addEventListener('updateready', logEvent, false);
function logEvent(e) {
var online, status, type, message;
online = (navigator.onLine) ? 'yes' : 'no';
status = cacheStatusValues[cache.status];
type = e.type;
message = 'online: ' + online;
message+= ', event: ' + type;
message+= ', status: ' + status;
if (type == 'error' && navigator.onLine) {
message+= ' (prolly a syntax error in manifest)';
}
console.log(message);
}
window.applicationCache.addEventListener(
'updateready',
function(){
window.applicationCache.swapCache();
console.log('swap cache has been called');
},
false
);
最後に、これは私のAndroid携帯に表示されるログです。
[cache Resource] app cache support!
[cache Resource] DOWNLOADING
[cache Resource] event online: yes, event: checking, status: uncached
[cache Resource] event online: yes, event: downloading, status: uncached
[cache Resource] event online: yes, event: progress, status: uncached
[cache Resource] event online: yes, event: progress, status: uncached
[cache Resource] event online: yes, event: error, status: uncached (prolly a syntax error in manifest)
画像はダウンロードされますが、最後の行でエラーが発生します。したがって、常にキャッシュされていません。
問題はウェブビュー設定またはAndroidアプリケーションにあると思います。しかし、私はそれを処理することはできません。
アプリのキャッシュを使用するためのヒントを教えてください..plz....