私は途方に暮れています。私はそれを簡潔にしようとします。Cordova/Phonegap 3.0 を使用します (2.8.0 でも同じ結果が得られます)。Android バージョン 4.0.4。コードは BlackBerry10 (Q10 および Z10) で動作します。
Android では、JSON エラーでエラーになります (いいえ、JSON を解析していません。これはコルドバの腸から出ているようです)。この末尾に JSON.stringified エラー オブジェクトを貼り付けます。
それでは、コードに進みます: まず、ファイルシステムの成功関数:
function onFSSuccess(fileSystem) {
if (fileSystem == null) {
window.alert("fileSystem is null");
}
var root = fileSystem.root;
root.getDirectory("com.app.id",{create:true},gotDir,onError);};
次に、ディレクトリ取得の成功を処理する関数:
function gotDir(d){
DATADIR = d;
doTheDl (d.fullPath + "/update.sql",fileTransfer);
};
次に、ファイルシステムを取得するための実際の呼び出し:
window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, onFSSuccess, null);
次に、ファイルをダウンロードする関数:
function doTheDl (localPath,fileTransfer) {
try {
window.alert ("Downloading to '" + localPath + "'");
fileTransfer.download (
uri,
localPath,
function (entry) {
try {
$("#dbDownloadProgressContainer").text("File saved to " + entry.name + ". Applying script to database...");
dbInitObj.applyUpdateScript(entry);
}
catch (e) {
window.alert ( e);
}
},
function (err) {
window.alert ("ERROROR!!! - " + err);
var errCodeName = err.code;
switch (err.code) {
case FileTransferError.FILE_NOT_FOUND_ERR:
errCodeName ='FILE_NOT_FOUND_ERR';
break;
case FileTransferError.INVALID_URL_ERR:
errCodeName="INVALID_URL_ERR";
break;
case FileTransferError.CONNECTION_ERR:
errCodeName="CONNECTION_ERR";
break;
case FileTransferError.ABORT_ERR:
errCodeName="ABORT_ERR";
break;
default:
errCodeName = "UNKNOWN";
break;
}
window.alert ("Download failed: " + err.source + ", " + err.target + ", " + errCodeName);
},
true
);
}
catch (e) {
window.alert ( e);
}
}
男、これらすべての非同期コールバックを気に入らなければなりません... 次に、問題の核心に到達し、ダウンロードしたファイルを読み取ろうとします。
//Bulk of applyUpdateScript script ommited, but eventually it gets here:
function readComplete (evt) {
$("#dbDownloadProgressContainer").text("Parsing script file...");
//Got this gem from here: http://beckism.com/2010/09/splitting-lines-javascript/
var lines = evt.target.result.match(/^.*([\n\r]+|$)/gm);
//var lineIndx = lines.length;
window.setTimeout(function () {
$("#dbDownloadProgressContainer").text("Processing " + lines.length + " statements");
},50);
};
try {
var fileReader = new FileReader();
fileReader.onloadend=readComplete;
fileReader.onerror=function (err) {
//var errStr = translateFileError (err);
window.alert ("FileReader.onerror: " +JSON.stringify (err));
};
fileReader.onloadstart=function (evt) {
window.alert ("FileReader.onloadstart - " + JSON.stringify (evt));
};
fileReader.onload=function (evt)
{
window.alert ("FileReader.onload - Called when the read has successfully completed.- " + JSON.stringify (evt));
};
fileReader.onprogress = function (evt)
{
window.alert ("FileReader.onprogress - " + JSON.stringify (evt));
}
fileReader.onabort = function (evt)
{
window.alert ("FileReader.onabort - " + JSON.stringify (evt));
}
function gotFile (fileEntry) {
window.alert ("Activating reader for file '" + fileEntry.fullPath + "'");
fileReader.readAsText(fileEntry);
};
function noFileFound (fileError) {
alert ("Can not access database update script: code " + translateFileError (fileError));
};
// window.alert ("scriptPath.name = " + scriptPath.name);
DATADIR.getFile (scriptPath.name,null,gotFile,noFileFound);
}
catch (e) {
window.alert (e);
}
今、読み取りビットにヒットすると、最終的に「onerror」イベントからこれを取得します(これはJSON.stringfiedエラーオブジェクトであることを思い出してください:
{
"type":"error",
"bubbles":false,
"cancelBubble":false,
"cancelable":false,
"lengthComputable":false,
"loaded":0,
"total":0,
"target":{
"_readyState":2,
"_error":{
"code":"JSON error"
},
"_result":null,
"_fileName":"file:///mnt/sdcard/com.app.id/update.sql",
"_realReader":{
"error":null,
"result":"",
"readyState":0
}
}
}
また、'com.app.id' は実際のアプリ ID のプレース ホルダーであることにも注意してください。機密性の高い名前を恐れて貼り付けることはできません。他のフォルダ名も試しました。その他の特筆すべき(?)アイテム:
- ダウンロード進行状況イベントは、実際のファイル サイズの正確に 2 倍 (wtf?) をダウンロードしていることを示しているようです。
- 結果はAndroidデバイスとエミュレーターで同じです
- BlackBerry10 は問題なく動作するようです
賢い人々に前もって感謝します....