最近因為一些項目的安全性需要將數據庫加密,一開始想到的就是先將數據庫通過AES加密,然后運行時再解密,另一種是將數據庫里的內容加密。 (PS:新建的QQ群,有興趣可以加入一起討論:Android學習交流群:278744577,驗證:eec) 很快這兩種方案都是不理想的,第一種加密方式形同虛設,第二種,如果加密的字段是要查找數據就變得麻煩。 所以第三種方案就是在內存里解密,在網上查到SQLITE是支持加密的, 所以就根據網上的指導一步步地將SQLITE編譯成支持加密的。 那下一步就是怎樣做成SDK去方便使用?第一個念頭就是將原生的數據庫使用方式移植過來,但做起來比開始想像的難了點,但最終也在修修補補中完成了移植工作。一開始是使用Android2.2的數據庫模塊源碼,但運行時會經常有一些問題出現,后來使用Android4.0的數據庫模塊源碼就解決了這些問題,當然,在開始是在Android4.0源碼編譯時,在Android4.0以上的手機運行是沒問題,但在Android4.0以下就會報錯。所以逼不得意就將Android4.0數據庫模塊移到Android2.2源碼目錄下編譯,當然少不了要解決版本兼用的一些問題。 Android原生是不支持數據庫加密的,所以要想加密數據庫就需要使用其它的方式。而這個SDK是從原生Android4.0源碼里單獨移植SQLITE模塊,并將這個模塊編譯時加入加密方法,因為SQLITE源碼中是有加密的接口,所以移植時就只需將這個預編譯參數加入和一些文件即可。 這個SDK只支持Android2.1以上的版本。 編譯環境: Android2.2源碼 Ubuntu12.10 64位 1、同步Android2.2源碼(大概4G容量) 2、安裝必需的依賴庫 3、在Android2.2源碼目錄下運行: [plain] view plain copy print ? $. build/envsetup.sh 這樣就可以初始化環境 4、去到這個源碼目錄,運行: [plain] view plain copy print ? $mm 這樣就可以編譯,生成結果在out\target\product\generic\system\lib\libsqlcrypt_jni.so 本來還想生成x86的庫,因為出現一些問題,還沒空去解決。 源碼下載地址:https://github.com/lendylongli/android-sqlite-encrypt |