3

私は途方に暮れています。私はそれを簡潔にしようとします。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 は問題なく動作するようです

賢い人々に前もって感謝します....

4

1 に答える 1

6

わかった。これが解決策でした:

    function gotFile (fileEntry) {
        fileEntry.file (function (file) {
        fileReader.readAsText(file);
    });
};

この男にBAJILLIONに感謝します: http://www.html5rocks.com/en/tutorials/file/filesystem/?ModPagespeed=noscript

見逃した方のために説明すると、魔法は fileEntry オブジェクトの "file(...)" 関数の呼び出しです。それなしでBB10で動作する理由....aarrgggghhh

于 2013-08-05T15:48:15.963 に答える