Android环境。getExternalStorageDirectory()不工作?
这是我以前的代码 私有静态最终字符串ROOTPATH=/data/data/ 我想将其更改为使用环境: 私有静态最终字符串根路径= getExternalStorageDirectory+/ 但我得到的结果是:Android环境。getExternalStorageDirectory()不工作?,android,Android,这是我以前的代码 私有静态最终字符串ROOTPATH=/data/data/ 我想将其更改为使用环境: 私有静态最终字符串根路径= getExternalStorageDirectory+/ 但我得到的结果是: > 08-12 10:53:09.131: E/SQLiteDatabase(1051): > android.database.sqlite.SQLiteCantOpenDatabaseException: unknown error > (code 14): Cou
> 08-12 10:53:09.131: E/SQLiteDatabase(1051):
> android.database.sqlite.SQLiteCantOpenDatabaseException: unknown error
> (code 14): Could not open database 08-12 10:53:09.131:
> E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnection.nativeOpen(Native Method)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:209)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:804)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:789)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)
> 08-12 10:53:09.131: E/SQLiteDatabase(1051): at
> android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:669)
以下是我的作品:
........
private static final String ROOTPATH = Environment.getExternalStorageDirectory()+"/";
private static final String DB_NAME_INDBNAME = "database.jpg";
private static final String DB_NAME_OUTDBNAME = "database.db";
......
public synchronized static NOLDatabaseHelper getInstance(Context context) {
if(dbHelper == null) {
dbHelper = new NOLDatabaseHelper(context);
}
return dbHelper;
}
private NOLDatabaseHelper(Context context) {
super(context, DB_NAME_OUTDBNAME, null, DB_VERSION);
this.context = context;
}
public void createDatabase() {
if(!isDatabaseExited())
{
Log.v(GlobalConfig.TAG, "NO database");
getReadableDatabase();
copyDataBaseFromAsset();
} else {
Log.v(GlobalConfig.TAG, "Has database");
}
}
private boolean isDatabaseExited() {
SQLiteDatabase checkDB = null;
try {
checkDB = SQLiteDatabase.openDatabase( ROOTPATH + DB_NAME_OUTDBNAME, null,
SQLiteDatabase.OPEN_READONLY);
checkDB.close();
} catch (SQLiteException e) {}
return checkDB != null ? true : false;
}
private synchronized void copyDataBaseFromAsset()
{
int length = -1;
byte[] buffer = new byte[1024];
AssetManager am = context.getAssets();
try
{
InputStream assetsDB = am.open(DB_NAME_INDBNAME);
String outFileName = ROOTPATH + DB_NAME_OUTDBNAME;
OutputStream dbOut = new FileOutputStream(outFileName);
while ((length = assetsDB.read(buffer)) > 0) {
dbOut.write(buffer, 0, length);
}
dbOut.flush();
dbOut.close();
assetsDB.close();
} catch(Exception e) {
Log.e( GlobalConfig.TAG, "copyDataBaseFromAsset error, is say: "+e.toString() );
}
}
createDatabase是从外部使用getInstance调用的。是否有任何错误或丢失的代码?我应该如何解决这个问题
非常感谢~ 变化
super(context, DB_NAME_OUTDBNAME, null, DB_VERSION);
到
在DatabaseHelper构造函数中,将ROOTPATH更改为
您是否在AndroidManifest.xml中添加了此权限?是的,我添加了~但仍然存在此问题。请将数据库打包到您的应用程序中。感谢您的帮助,我将尝试~有人可以建议如何改进此答案吗?您好,我尝试了此方法并解决了此问题,但我是否可以知道,Environment.getExternalStorageDirectory和Environment.getExternalStorageDirectory.getAbsolutePathEnvironment.getExternalStorageDirectory提供外部存储和环境的文件。getExternalStorageDirectory.getAbsolutePath提供该文件的路径。感谢您的帮助!还有一件事,如果用户卸载了SD卡,在这种情况下我应该使用哪个环境路径?我应该使用getDataDirectory吗?getFilesDir为您的应用程序提供内部存储路径
super(context, ROOTPATH + DB_NAME_OUTDBNAME, null, DB_VERSION);
ROOTPATH = Environment.getExternalStorageDirectory().getAbsolutePath()+"/";