最近由於一些項目的安全性須要將數據庫加密,一開始想到的就是先將數據庫經過AES加密,而後運行時再解密,另外一種是將數據庫裏的內容加密。 android
很快這兩種方案都是不理想的,第一種加密方式形同虛設,第二種,若是加密的字段是要查找數據就變得麻煩。 git
因此第三種方案就是在內存裏解密,在網上查到SQLITE是支持加密的, 因此就根據網上的指導一步步地將SQLITE編譯成支持加密的。 github
那下一步就是怎樣作成SDK去方便使用?第一個念頭就是將原生的數據庫使用方式移植過來,但作起來比開始想像的難了點,但最終也在修修補補中完成了移植工做。一開始是使用Android2.2的數據庫模塊源碼,但運行時會常常有一些問題出現,後來使用Android4.0的數據庫模塊源碼就解決了這些問題,固然,在開始是在Android4.0源碼編譯時,在Android4.0以上的手機運行是沒問題,但在Android4.0如下就會報錯。因此逼不得意就將Android4.0數據庫模塊移到Android2.2源碼目錄下編譯,固然少不了要解決版本兼用的一些問題。 sql
Android原生是不支持數據庫加密的,因此要想加密數據庫就須要使用其它的方式。而這個SDK是從原生Android4.0源碼裏單獨移植SQLITE模塊,並將這個模塊編譯時加入加密方法,由於SQLITE源碼中是有加密的接口,因此移植時就只需將這個預編譯參數加入和一些文件便可。 數據庫
這個SDK只支持Android2.1以上的版本。 安全
編譯環境:
Android2.2源碼
Ubuntu12.10 64位
一、同步Android2.2源碼(大概4G容量)
二、安裝必需的依賴庫
三、在Android2.2源碼目錄下運行:
ui
這樣就能夠編譯,生成結果在out\target\product\generic\system\lib\libsqlcrypt_jni.so 加密
原本還想生成x86的庫,由於出現一些問題,還沒空去解決。 spa
源碼下載地址:https://github.com/lendylongli/android-sqlite-encrypt .net