Guía de desarrollo

Local Navigation

Copia de una base de datos en una ubicación cifrada

Si copia una base de datos de SQLite en una ubicación de almacenamiento cifrada de un smartphone BlackBerry (eMMC o tarjeta microSD), la base de datos puede dejar de ser accesible para la API de base de datos. Esto sucede porque la tarjeta de memoria utiliza un tipo de cifrado diferente del que utiliza la API de base de datos.

Para copiar una base de datos a la que pueda acceder, debe utilizar la API de base de datos para crear un archivo de base de datos vacío, truncar el archivo a cero y, a continuación, copiar la base de datos en el archivo.

El ejemplo de código siguiente muestra esta técnica.

// Copy a database to an encrypted storage location. 
private void copyDBRecommendedWay() {
    try { 
        String dbPath = "file:///SDCard/original.db";
        String dbPathCopy = "file:///SDCard/copy.db";             
        Database dbCopy = null;
        try {
            // Delete if there's an existing one.
            DatabaseFactory.delete(URI.create(dbPathCopy));
           // Create the database using the DatabaseFactory class.                
            dbCopy = DatabaseFactory.create(URI.create(dbPathCopy));
        } catch (DatabaseException e) {
           System.out.println( "DatabaseException: error code: " 
                  + e.getErrorCode() + " msg: " + e.getMessage());        
        } finally {
            // Close the database.
            dbCopy.close();            
        }
        // Open a connection to the database file that was created.
        FileConnection outfc = (FileConnection)Connector.open(dbPathCopy);
        // Truncate the file.
        outfc.truncate(0);
        // Write out the downloaded database data to FileConnection.openOutputStream().
        OutputStream os = outfc.openOutputStream();
        FileConnection infc = (FileConnection)Connector.open(dbPath);        
        InputStream is = infc.openInputStream();
        byte[] buf = new byte[1024];
        int len;
        while ((len = is.read(buf)) > 0){
            os.write(buf, 0, len);
        }
        is.close();
        os.close();                     
        // Close the file connection.
        outfc.close();
        System.out.println("Copied " + dbPath + " to " + dbPathCopy);
        // The database can now be reopened with the DatabaseFactory class.
    } catch (Exception e) {
        System.out.println("Exception: " + e.getMessage());
    }
}    

¿Le ha resultado útil esta información? Envíenos sus comentarios.