SqliteOpenHelper for Mode_World_Readable,怎么样?

时间:2011-03-10 07:51:08

标签: android sqlite database-permissions

默认情况下,

SqliteOpenHelper会在mode_private中创建数据库。我们如何使用SqliteOpenHelper创建世界可读/可写的数据库?

或者我需要使用Context.openOrCreateDatabase()

2 个答案:

答案 0 :(得分:0)

  

我们如何使用SqliteOpenHelper创建世界可读/可写的数据库?

我们做不到。 ContextImpl.openOrCreateDatabase()实际上使用SQLiteDatabase.openOrCreateDatabase()方法打开/创建数据库,然后使用不属于公共API的类android.os.FileUtils设置数据库文件的权限。因此,除非您想使用反射,否则使数据库成为可读/可写的唯一可能方法是使用Context.openOrCreateDatabase()

答案 1 :(得分:0)

打开数据库作为世界可读/可写绝对是可能的。但那么数据库的必要性是什么?你可以用文件代替.. !!

不建议将数据库打开为世界可读/可写。

永远记住这一点:

  • 仅在必要时打开数据库, 因为它很贵。

  • 仅在必要模式下打开 读或写或两者兼而有之。

  • 操作后立即关闭它 结束了。

如果要在应用程序之间共享数据库或资源,可以使用SharedUserID。为了使用SharedUserID,应用程序必须使用相同的密钥进行签名。

如需更多信息,请参阅sree.cc上的帖子

http://sree.cc/google/android/sharing-resources-in-different-aplications-using-shareduserid

以下是相同的代码段:

private void getDB() {
        //accessing file using SHAREDUSERID
        try 
        { 
            //creating context from mainAPP for accessing database
            ctx = createPackageContext(
            "com.schogini.sharedDB.pack",
            Context.CONTEXT_IGNORE_SECURITY);
            if(ctx==null){
                return;
            }
        }
        catch (PackageManager.NameNotFoundException e) { 
            //package not found
            Log.e("Error",e.getMessage());
        }
        try
        { 
            File myDbFile = ctx.getDatabasePath("sharedDB.db");
            if (myDbFile.exists()) 
            {
                dbb = openOrCreateDatabase(myDbFile.getPath(), SQLiteDatabase.OPEN_READWRITE, null);
                dbb.setVersion(1);
                dbb.setLocale(Locale.getDefault());
                dbb.setLockingEnabled(true);
                try{
                    cur=dbb.rawQuery("select * from TABLENAME;",null);
                    try{
                        cur.moveToFirst();
                        int k=cur.getColumnCount();
                        lv_arr=new String[k];
                        for(int i=0;i<k;i++)
                        {
                            lv_arr[i]=""+cur.getString(i);
                            Toast.makeText(LaunchActivity.this, "Data "+i, Toast.LENGTH_SHORT).show();
                        }
                    }
                    catch(Exception e)
                    {
                        //may be an empty database
                        Log.e("Error",e.getMessage());
                        dbb.close();
                    }
                }
                catch(Exception e)
                {
                    Log.e("Error",e.getMessage());
                    dbb.close();
                }
            }
            else
            {
                //database not found
                Toast.makeText(LaunchActivity.this, "DataBase Doesnot Exist", Toast.LENGTH_SHORT).show();
            }
        }
       catch(Exception e)
       {
            Log.i("\n\nTAG",e.toString());
       }
}

不推荐:

如果你想要单词可读,那么创建它世界可读。使用openFileOutput()openOrCreateDatabase()。声明将数据库创建为全局可读的上下文。注意这种方法无论如何都不安全。

在这里做一个参考。

http://developer.android.com/reference/android/content/Context.html#MODE_WORLD_READABLE