android - SQLCipher 是否允许其他应用程序访问数据库。(如果 SD 卡中的数据库)

标签 android sqlcipher

我正在 SQLCiper 中尝试一件事。

这个东西在SD-CARD中的SQLite数据库中是成功的

1- 创建了一个应用 firstApp。在 SD-CARD

中有数据库

2- 创建了第二个应用 secondApp

我正在尝试在我的第二个应用程序中从 SD 卡读取数据。

编辑:- 我在 SDCARD 中的数据库。

public class SdcardCipherDataBase extends SQLiteOpenHelper
{

    public static final String  DATABASE_FILE_PATH = "/sdcard";
    public static final String  DATABASE_NAME = "sdCipherDatabase";
    public final static String NAME ="name";
    public final static String ADDRESS ="address";
    public final static String CITY ="city";

    public SdcardCipherDataBase(final Context context) {
        super(context,Environment.getExternalStorageDirectory()+File.separator+DATABASE_FILE_PATH + File.separator + DATABASE_NAME, null, 1);
    }


    @Override
    public void onCreate(SQLiteDatabase db) {
        try
        {  
            db.execSQL( "CREATE TABLE information(_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT, address TEXT,city TEXT);");

        }

        catch (SQLiteException ex)
        {
            Log.e("Hello", "error -- " + ex.getMessage(), ex);
        }
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
        db.execSQL("DROP Table mylistdata");
        onCreate(db);
    }
}

我在同一个应用程序中使用这个数据库:-

public void databasCollection()
    {
        SQLiteDatabase.loadLibs(this);
        File file = getDatabasePath("/mnt/sdcard/sdcard/sdCipherDatabase");
        file.mkdir();
        file.delete();
        db = SQLiteDatabase.openOrCreateDatabase(file, "myapp", null);
        sdb = new SdcardCipherDataBase(this);

        sdb.getWritableDatabase("myapp");
        ContentValues c = new ContentValues();
        c.put(SdcardCipherDataBase.NAME,"monty");
        c.put(SdcardCipherDataBase.ADDRESS,"BTM");
        c.put(SdcardCipherDataBase.CITY,"Bangalore");
        db.insert("information", SdcardCipherDataBase.NAME, c);
        db.close();
    }

但我想在其他应用程序中使用相同的数据库。

我正在尝试做这样的事情

public void databaseFromOtherApp()
{
    SQLiteDatabase.loadLibs(this);
    File file = getDatabasePath("/mnt/sdcard/sdcard/sdCipherDatabase");
    db = SQLiteDatabase.openOrCreateDatabase(file, "myapp", null);
    dh = new DatabaseHelper(this);

    Cursor cursor = db.rawQuery("select * from information", null);
    cursor.moveToFirst();
    String s = cursor.getString(cursor.getColumnIndex(NAME));
    Toast.makeText(this,"Name is "
            +s, Toast.LENGTH_LONG).show();

    cursor.close();
    db.close();
}

但显示错误。

 Caused by: net.sqlcipher.database.SQLiteException: no such table: information: , while compiling: select * from information

最佳答案

您的第二个应用中的这一行是错误的:

dh = new DatabaseHelper(this);

您的第二个应用程序中也需要一个 SdcardCipherDataBase 实例,因为该类知道表和表名。目前您使用的是普通的 DatabaseHelper,它不知道要查找什么。

更新:
即使你能做你需要做的事,这也不是明智之举。如您所见,您需要将所有与数据库相关的逻辑复制到使用它的任何其他应用程序。如果您需要第三个应用程序来做同样的事情怎么办?再次复制所有类(class)?如果您需要修改表以添加新列怎么办?您必须修改所有三个应用程序中的类。通常,您会希望将数据库访问层保留在第一个应用中,并通过内容提供程序提供对其他应用的访问。

关于android - SQLCipher 是否允许其他应用程序访问数据库。(如果 SD 卡中的数据库),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14603777/

相关文章:

java - 在 SQLCipher 中设置密码

java - 如何使用 Android/Java 加速图像处理?

android - 如何用fetch填充react native的选择器(android)

android - QuickBlox 通知 : push token disappears

安卓 SQL 错误

android - SQLCipherUtils.getDatabaseState 中带有 Room Persistence Library 异常的 SQLCipher

android - 我如何加密 Android SQLite 数据库中的特定列数据。使用 SQLCipher 实用程序

java - "Comparison method violates its general contract!"但我只比较两个长值?

使用 SQLCipher 的 Android - 你如何解密?

Ubuntu 中不支持 SQLCipher 的 SQLite 浏览器