2012-07-16 5 views
0

안녕하세요.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);을 초기화.

아무도 모른다면 누군가가 잘못 될 수 있음을 지적 할 수 있습니까?

감사합니다.

답변

0

SQLiteDatabase.openOrCreateDatabase으로 전화 한 후 데이터베이스 스키마를 만들거나 데이터베이스 마이그레이션을 관리하기 위해 net.sqlcipher.datdatabase.SQLiteOpenHelper의 하위 클래스를 만들고 있습니까? 그것없이 당신의 테이블 이름은 존재하지 않을 것입니다. 어쩌면 당신이보고있는 문제를 진단하는 데 도움이되는 코드를 더 많이 표시 할 수 있습니다.

+0

파일을 만들 때 즉시 sampleDB.execSQL을 사용하여 여러 테이블을 만듭니다. 당신이 방금 말했듯이, 내가 다른 테이블에서 파일을 열려고 할 때 나는 모든 테이블이 손상되지 않았다고 가정하고 (암호화되지 않았을 때) 삽입하려고 시도합니다. SQLiteOpenHelper를 사용하지 않습니다. 필요합니까? – user1529205

+2

필요에 따라, net.sqlcipher.database.SQLiteOpenHelper를 사용하면 애플리케이션이 변경 될 때 스키마 마이그레이션을 수행 할 수 있으므로 매우 유용합니다. 당신이 이것을 다시 구현하는 것 같네요. 아마도 [docs] (http://developer.android.com/reference/android/database/sqlite/SQLiteOpenHelper.html)를 확인하십시오. 또한 응용 프로그램 논리를 배제하려면 표 작성 다음에 insert 문을 던져서 무엇이 발생하는지보십시오. –

0

전화를 걸려면 "암호"를 입력하면됩니다.

관련 문제