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

Unk*_*own 6 android sqlcipher

我在SQLCiper尝试一件事.

这件事在SQLite数据库中取得了成功 SD-CARD

1-创建一个应用程序firstApp.与数据库在SD-CARD

2-创建的第二应用程序secondApp.

我试图在我的第二个应用程序中读取SD-CARD中的数据.

编辑: - 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);
    }
}
Run Code Online (Sandbox Code Playgroud)

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

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();
    }
Run Code Online (Sandbox Code Playgroud)

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

我想做一些这样的事情

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();
}
Run Code Online (Sandbox Code Playgroud)

但显示错误.

 Caused by: net.sqlcipher.database.SQLiteException: no such table: information: , while compiling: select * from information
Run Code Online (Sandbox Code Playgroud)

Mis*_*ith 2

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

dh = new DatabaseHelper(this);
Run Code Online (Sandbox Code Playgroud)

您的第二个应用程序中还需要一个also的实例SdcardCipherDataBase,因为该类知道表和表名。目前您正在使用一个DatabaseHelper不知道要寻找什么的平原。

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