版权声明:本文为博主原创文章,未经博主允许不得转载。

转载请表明出处:http://www.cnblogs.com/cavalier-/p/6241964.html

前言

大家好,我是Cavalier,这次和大家分享的主题是数据库加密。当今移动互联网数据安全至关重要,而数据库是Android常用的数据持久化方案,但是原生的sqLite并不支持密码加密,目前常用的数据库加密方式大部分是字段加密,或者是内容加密。这里特别推荐使用sqlcipher的数据库加密方案,使用与原生一致,(sqlcipher-android的Github地址请戳),下面分享一下源码编译的过程和遇到的错误。

编译前奏

博主当前环境是:

Mac ox 10.12.2 (16C67)

Java 1.8.0_112

Ant 1.9.8

Android NDK 12.1.3345770

下载源码

(sqlcipher-android的Github地址请戳)

从上面提供的地址中克隆下来(tip:我尝试了直接下载源码ZIP包,但是在后面的编译中会报错,报错内容看文后)

git clone https://github.com/sqlcipher/android-database-sqlcipher.git

从github克隆源码非常慢...

克隆下来后,就可以直接运行make命令了

make init

执行完后再执行make就好了

make

当make执行完后,会在目录下生成libs目录,里面就有了咱们需要的jar包和so动态库

遇到的问题

1.make init 没问题,但是执行make时报如下错误:

ant relese
permission denied

这个错误,我尝试了sudo -s命令发现没效果,尝试修改了源文件的权限也不行,但是我尝试了which ant 发现报了not fond,修复方案就是从Apache下载一个最新版本的Ant,解压后添加进系统变量

open ~/.bash_profile

打开后添加自己的路径

export ANT_HOME=(此处填写你刚下载的Ant绝对路径)

export PATH=${ANT_HOME}/bin:$PATH

配置环境变量

source ~/.bash_profile

这时输入

ant -version

如果输出具体版本号即为配置成功,配置ant成功后即可以重新make一下就好了

2.ant也确定安装没问题,但是make还是报错,错误如下:

Unable to locate tools.jar

这时就需要检查一下环境变量中JAVA_HOME和CLASSPATH的配置,正确的配置应该如下

export JAVA_HOME="/Library/Java/JavaVirtualMachines/jdk1.8.0_112.jdk/Contents/Home"
export PATH=${JAVA_HOME}/bin:$PATH
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export CLASSPATH

重新配置后就可尝试make一下即可成功编译

3.检查过JAVA_HOME没问题,ANT_HOME也没问题,但是还是编译不成功,错误如下:

Buildfile: build.xml does not exist!
Build failed
make: *** [build-java] Error 1

这个就说明源码中是没有带build.xml的,这时咱们可以通过如下命令生成一个

android update project --target 1 --path ./ --subprojects

这时会在源码目录中多出一个build.xml,重新make一下就好了

sqlcipher的使用

如原生的数据库操作一致

特别注意事项

由于Android平台4.0到7.0跨度太大,以至于如果项目是用旧的动态库会报一个警告,且这个警告是不可控的,对用户体验非常不好。推荐使用当前最新版本即可

总结

希望大家通过如上简单的介绍后,对sqlcipher源码编译没有问题。

以上纯属个人经验,喜欢的请点个推荐哦,如有错误请指出,谢谢大家,。

版权声明:本文为博主原创文章,未经博主允许不得转载。

转载请表明出处:http://www.cnblogs.com/cavalier-/p/6241964.html

Android数据库加密之sqlciher方案的更多相关文章

  1. Android 数据库加密

    一 一个简短的引论   SQLite是一个轻量的.跨平台的.开源的数据库引擎.它的读写效率.资源消耗总量.延迟时间和总体简单性上具有的优越性,使其成为移动平台数据库的最佳解决方式(如Android.i ...

  2. SpringBoot使用Druid数据库加密链接完整方案

    网上的坑 springboot 使用 Druid 数据库加密链接方案,不建议采用网上的一篇文章<springboot 结合 Druid 加密数据库密码遇到的坑!>介绍的方式来进行加密链接实 ...

  3. Android数据存储之SQLCipher数据库加密

    前言: 最近研究了Android Sqlite数据库(文章地址:Android数据存储之Sqlite的介绍及使用)以及ContentProvider程序间数据共享(Android探索之ContentP ...

  4. Android数据库(sqlite)加密方案

    最近因为一些项目的安全性需要将数据库加密,一开始想到的就是先将数据库通过AES加密,然后运行时再解密,另一种是将数据库里的内容加密. 很快这两种方案都是不理想的,第一种加密方式形同虚设,第二种,如果加 ...

  5. Android DB那些事-数据库加密

    说到数据库加密,目前最好且唯一的方案就是SqlCipher对sqlite3整体加密,微信也用的它.开源,且支持很多平台. 单就Android来说,集成不算太麻烦,1个jar包,3个so库,1个zip. ...

  6. Android Sqlite数据库加密

    Android使用的是开源的SQLite数据库,数据库本身没有加密,加密思路通常有两个: 1. 对几个关键的字段使用加密算法,再存入数据库 2. 对整个数据库进行加密 SQLite数据库加密工具: 收 ...

  7. [DB那些事]数据库加密

    说到数据库加密,目前最好且唯一的方案就是SqlCipher对sqlite3整体加密,微信也用的它.开源,且支持很多平台. 单就Android来说,集成不算太麻烦,1个jar包,3个so库,1个zip. ...

  8. iOS 使用FMDB SQLCipher给数据库加密

    关于SQLite,SQLCipher和FMDB SQLite是一个轻量的.跨平台的.开源的数据库引擎,它的在读写效率.消耗总量.延迟时间和整体简单性上具有的优越性,使其成为移动平台数据库的最佳解决方案 ...

  9. Android Learning:数据存储方案归纳与总结

    前言 最近在学习<第一行android代码>和<疯狂android讲义>,我的感触是Android应用的本质其实就是数据的处理,包括数据的接收,存储,处理以及显示,我想针对这几 ...

随机推荐

  1. vim 大全用法

    vim中常用设置和操作: 在Linux系统下: 打开vi 文件: 0 数字0,跳转至行首    ^ 跳转至行第一个非空字符    $ 跳转至行尾 vim 括号匹配跳转操作: ctrl+] 跳转至函数或 ...

  2. CSS动画与GPU

    写在前面 满世界的动画性能优化技巧,例如: 只允许改变transform.opacity,其它属性不要动,避免重新计算布局(reflow) 对动画元素应用transform: translate3d( ...

  3. 解决:jmeter查看结果树的响应数据提示超过最大值Response too large to be displayed

    问题:用jmeter做接口测试时,查看结果树的数据没有显示全,给出下面的错误提示 Response too large to be displayed. Size: 1349830 > Max: ...

  4. jquery里面的名称冲突解决方法

    jQuery 使用 $ 符号作为 jQuery 的简介方式. 某些其他 JavaScript 库中的函数(比如 Prototype)同样使用 $ 符号. jQuery 使用名为 noConflict( ...

  5. LINQ to XML 编程基础

    1.LINQ to XML类 以下的代码演示了如何使用LINQ to XML来快速创建一个xml: 隐藏行号 复制代码 ?创建 XML public static void CreateDocumen ...

  6. IT学习网站集结

    IT的学习网站: 慕课网   http://www.imooc.com 51CTO   http://www.51cto.com/ CSDN    http://www.csdn.net/ 极客   ...

  7. JavaBean的toString方法工具类

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

  8. MongoDB学习:(一)MongoDB安装

    MongoDB学习:(一)MongoDB安装 MongoDB介绍:     直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...

  9. List<Map<String,Object>>使用Java代码遍历

    List<Map<String,Object>>的结果集怎么使用Java代码遍历以获取String,Object的值: package excel; import java.u ...

  10. iOS实现类似于歌词进度效果

    先看效果 这里关键的地方在于镂空文字的实现,可以用UILabel的drawRect方法. .h文件 @interface HollowLabel : UILabel @end .m文件 @interf ...