안녕하세요.Android와 함께 SQLCipher. 작성이 잘 작동하고 선택 + 삽입하지 마십시오
이String dbPath = context.getDatabasePath(NAME_OF_MY_FILE).getPath();
SQLiteDatabase sampleDB = SQLiteDatabase.openOrCreateDatabase(dbPath, "password", null);
이 잘 작동하고 파일이 나는 등의 여러 오류를 얻을이 암호화 된 파일에 액세스하려고 할 때 비록 작성됩니다
는 다음 코드와 안드로이드 응용 프로그램에서 암호화 된 데이터베이스 파일을 만드는 오전 :
그런 테이블 TABLE_NAME 및 파일은 암호화 또는 함수가라고되어 있기 때문에, 데이터베이스
단순히 편집을 위해 파일을 열도록 동일한 코드를 사용하고하지 않다. 파일을 여는 프로세스가 단순히 생성의 역순이라고 가정하고 원래 암호를 전달합니까?
내가 올바른 가져 오기를 사용하고 있습니다 :
import net.sqlcipher.database.SQLiteDatabase;
과 onCreate()
방법 SQLiteDatabase.loadLibs(this);
을 초기화.
아무도 모른다면 누군가가 잘못 될 수 있음을 지적 할 수 있습니까?
감사합니다.
파일을 만들 때 즉시 sampleDB.execSQL을 사용하여 여러 테이블을 만듭니다. 당신이 방금 말했듯이, 내가 다른 테이블에서 파일을 열려고 할 때 나는 모든 테이블이 손상되지 않았다고 가정하고 (암호화되지 않았을 때) 삽입하려고 시도합니다. SQLiteOpenHelper를 사용하지 않습니다. 필요합니까? – user1529205
필요에 따라, net.sqlcipher.database.SQLiteOpenHelper를 사용하면 애플리케이션이 변경 될 때 스키마 마이그레이션을 수행 할 수 있으므로 매우 유용합니다. 당신이 이것을 다시 구현하는 것 같네요. 아마도 [docs] (http://developer.android.com/reference/android/database/sqlite/SQLiteOpenHelper.html)를 확인하십시오. 또한 응용 프로그램 논리를 배제하려면 표 작성 다음에 insert 문을 던져서 무엇이 발생하는지보십시오. –