嘿,伙计们,我在安卓系统的SQLcipher数据库上遇到了一些问题,文档不太具描述性,所以我想不出来。
我正在尝试修改sqlcipher for android的默认迭代次数,我正在编辑通过sqlcipher作为演示应用程序提供的notecipher应用程序,并希望将kdf_iter增加到例如5000
通过覆盖数据库帮助器中的getWritableDatabase()方法,我在使用密码打开文件后立即输入杂注。
我可以打开并初始化数据库,但如果调用database.close(),则无法重新打开数据库。
每当我在下一次open()调用中关闭数据库时,我都会得到一个:
I/Database(807): sqlite returned: error code = 26, msg = file is encrypted or is not a database
E/Database(807): CREATE TABLE android_metadata failed
E/Database(807): Failed to setLocale() when constructing, closing the database
E/Database(807): info.guardianproject.database.sqlcipher.SQLiteException: file is encrypted or is not a database发布于 2015-11-09 22:32:15
@Stephen的回答只有部分正确,因为根据documentation
PRAGMA kdf_iter必须在 PRAGMA key之后、第一次实际数据库操作之前调用,否则将不起作用。
所以这句话:
这对我很有效。
发布于 2012-11-26 02:19:27
您将希望使用SQLiteDatabaseHook对象来调用kdf_iter杂注。这将确保在打开数据库之后但在使用之前立即调用杂注。
SQLiteDatabaseHook hook = new SQLiteDatabaseHook(){
public void preKey(SQLiteDatabase database){
database.rawExecSQL("PRAGMA kdf_iter = 5000");
}
public void postKey(SQLiteDatabase database){}
}
SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(databasePath, password, null, hook);https://stackoverflow.com/questions/13537073
复制相似问题