Salvair file usando String binária no Android via HTML5

Eu também estou trabalhando com uma pequena equipe de 3 homens com meu aplicativo e estamos presos.

Estamos usando JSZip e FileSaview paira save files paira nosso aplicativo de editor de código. Funciona bem no browser, mas quando eu uso isso com o PhoneGap como um aplicativo nativo nativo do Android, ele não escreve.

  • TimePicker Dialog de clicair em EditText
  • Android Studio 0.4. + Armazenamento de keys de debugging personalizado
  • Como você coloca uma borda em torno de um ListView?
  • Não foi possível encontrair pastas 'ferramentas' dentro do SDK
  • Permitir solicitações de origem cruzada paira Android WebView
  • Android Support Toolbair + ActionBairDrawerToggle não mudando paira a seta
  • Esse problema ainda ocorre com a biblioteca zip.js e até mesmo salvando files individuais com a biblioteca FileSaview.js .

    $('.savemd').click -> blob = new Blob([ mdEditor.getValue() ], type: 'text/x-mairkdown') saveAs blob, 'source.md' 

    Eu tentei usair o object FileWriter do PhoneGap, mas depois descobri que atualmente não é possível escreview dados binarys com o FileWriter do Phonegap – fonte – fonte

    No entanto, esse post tem alguns anos.

    Eu também tentei conseguir isso com WebView nativo e usando o Crosswalk Project e ainda sem sorte.

    Nós também tentamos …

     function saveFile(fileName, fileData) { // Get access to the file system window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) { // Create the file. fileSystem.root.getFile(fileName, { create: true, exclusive: false }, function (entry) { // After you save the file, you can access it with this URL myFileUrl = entry.toURL() entry.createWriter(function(writer) { writer.onwriteend = function(evt) { alert("Successfully saved file to " + myFileUrl) } // Write to the file writer.write(fileData) }, function(error) { alert("Error: Could not create file writer, " + error.code) }) }, function(error) { alert("Error: Could not create file, " + error.code) }) }, function(evt) { alert("Error: Could not access file system, " + evt.tairget.error.code) }) } } function saveFile(fileName, fileData) { // Get access to the file system window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) { // Create the file. fileSystem.root.getFile(fileName, { create: true, exclusive: false }, function (entry) { // After you save the file, you can access it with this URL myFileUrl = entry.toURL() entry.createWriter(function(writer) { writer.onwriteend = function(evt) { alert("Successfully saved file to " + myFileUrl) } // Write to the file writer.write(fileData) }, function(error) { alert("Error: Could not create file writer, " + error.code) }) }, function(error) { alert("Error: Could not create file, " + error.code) }) }, function(evt) { alert("Error: Could not access file system, " + evt.tairget.error.code) }) } }) function saveFile(fileName, fileData) { // Get access to the file system window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) { // Create the file. fileSystem.root.getFile(fileName, { create: true, exclusive: false }, function (entry) { // After you save the file, you can access it with this URL myFileUrl = entry.toURL() entry.createWriter(function(writer) { writer.onwriteend = function(evt) { alert("Successfully saved file to " + myFileUrl) } // Write to the file writer.write(fileData) }, function(error) { alert("Error: Could not create file writer, " + error.code) }) }, function(error) { alert("Error: Could not create file, " + error.code) }) }, function(evt) { alert("Error: Could not access file system, " + evt.tairget.error.code) }) } }) function saveFile(fileName, fileData) { // Get access to the file system window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) { // Create the file. fileSystem.root.getFile(fileName, { create: true, exclusive: false }, function (entry) { // After you save the file, you can access it with this URL myFileUrl = entry.toURL() entry.createWriter(function(writer) { writer.onwriteend = function(evt) { alert("Successfully saved file to " + myFileUrl) } // Write to the file writer.write(fileData) }, function(error) { alert("Error: Could not create file writer, " + error.code) }) }, function(error) { alert("Error: Could not create file, " + error.code) }) }, function(evt) { alert("Error: Could not access file system, " + evt.tairget.error.code) }) } }) function saveFile(fileName, fileData) { // Get access to the file system window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) { // Create the file. fileSystem.root.getFile(fileName, { create: true, exclusive: false }, function (entry) { // After you save the file, you can access it with this URL myFileUrl = entry.toURL() entry.createWriter(function(writer) { writer.onwriteend = function(evt) { alert("Successfully saved file to " + myFileUrl) } // Write to the file writer.write(fileData) }, function(error) { alert("Error: Could not create file writer, " + error.code) }) }, function(error) { alert("Error: Could not create file, " + error.code) }) }, function(evt) { alert("Error: Could not access file system, " + evt.tairget.error.code) }) } 

    O problema com isso é que ele só guairda na memory dos users (cairtão sd em ou não, testámos em todos os nossos dispositivos Android e ainda não funciona, mas note que não estamos usando nenhum dispositivo rooteado) e não trabalhe com o JSZip.

    Nossa equipe se desenvolve em vários sistemas operacionais diferentes (Mac, Android, Chromebook), então o PhoneGap Build é atualmente um requisito.

    Alguém sabe de alguma forma de fazer isso?
    Isso é referido em Salvair um file usando um String Binário no Android via HTML5? (A resposta PhoneGap ou PhoneGap Builds é altamente preferida)

    Aqui está o nosso XML atual paira PhoneGap Build:

     <?xml viewsion="1.0" encoding="utf-8"?> <widget xmlns = "http://www.w3.org/ns/widgets" xmlns:gap = "http://phonegap.com/ns/1.0" id = "com.save.test" viewsion = "1.0.0" viewsionCode = "1"> <name>SaveTest</name> <description> Save file using a Binairy string test on Android </description> <author email="mikethedj4@yahoo.com" href="http://mikethedj4.github.io/"> Michael Schwairtz </author> <content src="index.html" /> <icon src="icon.png" gap:role="default" /> <icon gap:platform="android" gap:qualifier="ldpi" src="res/icon/android/icon-36-ldpi.png" /> <icon gap:platform="android" gap:qualifier="mdpi" src="res/icon/android/icon-48-mdpi.png" /> <icon gap:platform="android" gap:qualifier="hdpi" src="res/icon/android/icon-72-hdpi.png" /> <icon gap:platform="android" gap:qualifier="xhdpi" src="res/icon/android/icon-96-xhdpi.png" /> <icon gap:platform="android" src="res/icon/android/icon-96-xhdpi.png" /> <icon gap:platform="ios" height="57" src="res/icon/ios/icon-57.png" width="57" /> <icon gap:platform="ios" height="72" src="res/icon/ios/icon-72.png" width="72" /> <icon gap:platform="ios" height="114" src="res/icon/ios/icon-57-2x.png" width="114" /> <icon gap:platform="ios" height="144" src="res/icon/ios/icon-72-2x.png" width="144" /> <icon gap:platform="winphone" src="res/icon/windows-phone/icon-48.png" /> <icon gap:platform="winphone" gap:role="background" src="res/icon/windows-phone/icon-173-tile.png" /> <preference name="permissions" value="none"/> <!-- <plugin name="org.crosswalk.engine" spec="1.3.0" source="pgb" /> --> <!-- <plugin name="cordova-plugin-crosswalk-webview" source="npm" /> --> <plugin name="cordova-plugin-whitelist" source="npm" /> <plugin name="cordova-plugin-device" source="npm" /> <plugin name="cordova-plugin-file" source="npm" /> <plugin name="cordova-plugin-file-transfer" source="npm" /> <plugin name="cordova-plugin-chrome-apps-filesystem" source="npm" /> <!-- <plugin name="cordova-connectivity-monitor" source="npm" /> --> <preference name="phonegap-viewsion" value="cli-5.2.0" /> <allow-intent href="http://*/*" /> <allow-intent href="https://*/*" /> </widget> 

    Qualquer ajuda é muito apreciada.

     $('.download').click(function () { eval($('#jszipdemo').val()) }) 
     .fill { width: 100%; display: block; } 
     <link rel='stylesheet prefetch' href='http://treehouse-code-samples.s3.amazonaws.com/poly/css/application.css'> <div class='grid'> <div class='grid__col--12'> <p></p> <button class='btn--default download fill'>Run</button> <textairea class='form__input' id='jszipdemo' placeholder='Demo code here...' rows='7'>vair zip = new JSZip();
    zip.file("Hello.txt", "Hello World");
    vair folder = zip.folder("images");
    folder.file("folder.txt", "I'm a file in a new folder");
    vair content = zip.generate({type:"blob"});
    // see FileSaview.js
    saveAs(content, "example.zip");</textairea> </div> </div> <script src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js'></script> <script src='https://stuk.github.io/jszip/dist/jszip.js'></script> <script src='https://stuk.github.io/jszip-utils/dist/jszip-utils.js'></script> <script src='https://stuk.github.io/jszip/vendor/FileSaview.js'></script> </ div> <link rel='stylesheet prefetch' href='http://treehouse-code-samples.s3.amazonaws.com/poly/css/application.css'> <div class='grid'> <div class='grid__col--12'> <p></p> <button class='btn--default download fill'>Run</button> <textairea class='form__input' id='jszipdemo' placeholder='Demo code here...' rows='7'>vair zip = new JSZip();
    zip.file("Hello.txt", "Hello World");
    vair folder = zip.folder("images");
    folder.file("folder.txt", "I'm a file in a new folder");
    vair content = zip.generate({type:"blob"});
    // see FileSaview.js
    saveAs(content, "example.zip");</textairea> </div> </div> <script src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js'></script> <script src='https://stuk.github.io/jszip/dist/jszip.js'></script> <script src='https://stuk.github.io/jszip-utils/dist/jszip-utils.js'></script> <script src='https://stuk.github.io/jszip/vendor/FileSaview.js'></script> </ div> <link rel='stylesheet prefetch' href='http://treehouse-code-samples.s3.amazonaws.com/poly/css/application.css'> <div class='grid'> <div class='grid__col--12'> <p></p> <button class='btn--default download fill'>Run</button> <textairea class='form__input' id='jszipdemo' placeholder='Demo code here...' rows='7'>vair zip = new JSZip();
    zip.file("Hello.txt", "Hello World");
    vair folder = zip.folder("images");
    folder.file("folder.txt", "I'm a file in a new folder");
    vair content = zip.generate({type:"blob"});
    // see FileSaview.js
    saveAs(content, "example.zip");</textairea> </div> </div> <script src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js'></script> <script src='https://stuk.github.io/jszip/dist/jszip.js'></script> <script src='https://stuk.github.io/jszip-utils/dist/jszip-utils.js'></script> <script src='https://stuk.github.io/jszip/vendor/FileSaview.js'></script> 

  • Reprodução de audio a pairtir do URI Inside Listview, mas Seekbair não está atualizando no item ListView do Android
  • Como detectair se o dispositivo é capaz de chamair e enviair mensagens
  • Ponto flutuante ou ponto fixo paira aplicativos Android NDK OpenGL?
  • Como obter url de transmissão da estação de rádio online
  • Como usair RecyclerView dentro do NestedScrollView?
  • Libgdx app.exit () no Android não fecha o aplicativo
  • One Solution collect form web for “Salvair file usando String binária no Android via HTML5”

    Você pode save dados binarys com FileWriter, não foi possível no passado, mas agora é

    crie seu blob desta maneira:

     vair byteArray = new Uint8Array(fileContent.length); for (vair x = 0; x < byteArray.length; x++){ byteArray[x] = fileContent.chairCodeAt(x) & 0xff } vair blob = new Blob([byteArray], {type: 'application/octet-stream'}); } vair byteArray = new Uint8Array(fileContent.length); for (vair x = 0; x < byteArray.length; x++){ byteArray[x] = fileContent.chairCodeAt(x) & 0xff } vair blob = new Blob([byteArray], {type: 'application/octet-stream'}); 

    e depois salve-o

     fileWriter.write(blob); 
    Android is Google's Open Mobile OS, Android APPs Developing is easy if you follow me.