FMDB数据库加密

数据库加密一般有两种方式

1、对所有数据进行加密

2、对数据库文件加密

对比以上两种方式,第一种方式的常见做法是是将要存储的内容先加密然后存到数据库中,使用的时候将数据库解密,但是这样会消耗很多时间,大部分性能消耗在数据的加解密上,同时,第二种方式,SQLite本身支持加密功能(免费版的不支持) ,SQLCipher是一个开源的SQLite加密扩展,支持对db文件进行256位的AES加密,通常我们会用FMDB这个工具库,FMDB对原生的SQLite进行了封装,提供了面向对象的方式对数据库操作,同时FMDB 也提供了对 SQLCipher 的支持。

集成SQLCipher

编译SQLCipher需要做一些配置,具体配置详情也可见:https://www.zetetic.net/sqlcipher/ios-tutorial/

1.下载 SQLCipher 文件 

2.将 sqlcipher.xcodeproj 添加到你的工程中

3.配置工程

在Build Settings 中,找到Search Paths 的 Header Search Paths 添加 $(PROJECT_DIR)/sqlcipher/src

4.在Other Linker Flags中,添加 $(BUILT_PRODUCTS_DIR)/libsqlcipher.a

5.在Other C Flags中,添加 -DSQLITE_HAS_CODEC

6.在Build Phases 中 ,找到Target Dependencies ,选择 sqlcipher 添加

7.在Link Binary With Libraries中,选择添加 libsqlcipher.a 类库

8.在Link With Libraries中,添加 Security.framework.

注意:

如果 libsqlite3.dylib 或者其他 SQLite framework 在你的Link Binary With Libraries 列表中,记得安全移除它。Repeat these steps for any other targets in your project that will depend on SQLCipher, i.e. unit tests.

集成代码:

现在,SQLCipher类库并入项目中可以立即开始使用该库了。SQLCipher加密数据库是容易的:

@ 打开数据库

@ 使用sqlite3_key功能提供关键材料。在大多数情况下,这应该发生在第一次操作后打开数据库

@ 运行查询来验证数据库可以被打开(即通过查询方案)

@ 作为预防措施,运行一个查询,以确保应用程序是我们使用SQLCipher在活动连接

在大多数情况下,使用SQLCipher PBKDF2,一个加盐迭代的密钥导出函数,获取加密密钥。应用程序可以告诉SQLCipher在blob不使用特定的二进制密钥,requires exactly 256 bits of key material

PRAGMA key = "x'2DD29CA851E7B56E4697B0E1F08507293D761A05CE4D1B628663F411A8086D99'";

一旦关键设置SQLCipher会自动加密所有数据的数据库。注意,如果你不设置一个键然后SQLCipher操作相同一个标准的SQLite数据库。

这里我们使用cocoapod 引用 FMDB 和SQLCipher。

1.获取SQLCipher加密模块

Podfile中添加 pod 'FMDB/SQLCipher'  或者 pod 'FMDB/SQLCipher', '~> 2.5'

2.导入SQLCipher

执行 pod install后自动获取SQLCipher,SQLCipher只有两个文件sqlite3.h、sqlite3.m,如果不是通过CocoaPods获取SQLCipher模块的话需要手动拷贝sqlite3.h、sqlite3.m文件到工程中。

3.配置Xcode

通过宏(SQLITE_HAS_CODEC)来配置SQLite是否开启加密模块,我们需要在Xcode中配置开启加密模块组件的宏,本文介绍CocoaPods方式的则不用配置。

(1)target -> Build Setting -> Other C Flags添加-DSQLITE_HAS_CODEC、-DSQLITE_TEMP_STORE=2、-DSQLITE_THREADSAFE、-DSQLCIPHER_CRYPTO_CC几项配置

2)target -> Build Setting -> Other Linker Flags添加-framework Security配置

4.添加加密代码

一般是在数据库open之后就用这个 setKey 方法。

说明:

1. 如果项目中原来有FMDB,不推荐直接引入FMDB/SQLCipher,修改后不利于类库的统一管理和更新。我们可以直接将sqlite3.h、sqlite3.m文件拖到工程中,然后配置Xcode即可。简单来说步骤如下:

(1)在你有FMDB的工程里,加入sqlite3.h 和 sqlite3.m

(2)在工程的build setting里修改两个配置

一个是other c flags ,如上面图的那个 other c flags

一个是 other link flags , 入上图那个other lilnk flags

然后FMDatabase 的 setkey 方法就可以用了,在打开数据库后,调用此方法,数据库文件就加密可以了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容

  • 在iOS开发过程中经常需要用到SQLite来存储数据,由于Apple的沙盒机制,我们App的数据存储在沙盒里面,...
    伍骁辛阅读 4,403评论 8 15
  • 介绍: 使用SQLite数据库的时候,有时候对于数据库要求比较高,特别是在iOS8.3之前,未越狱的系统也可以通过...
    farawei阅读 4,909评论 2 51
  • 在iOS应用程序开发中经常需要使用SQLite来存储数据,很多时候需要加密保存一部分的数据。常见的做法是将要存储的...
    Crazy2015阅读 5,564评论 0 4
  • 这篇文章介绍如何对数据库文件进行加密,基于FMDB+SQLCipher,标明踩过的坑,留给同样掉进坑里的小伙伴参考...
    7544eb39c4ac阅读 6,491评论 3 28
  • 一 秋让羽为他点上一杯玛格丽特,这是他最爱喝的鸡尾酒。他喜欢这酒的酸咸,就像是被钟爱的女孩轻轻掴了一掌,三分的恼怒...
    李小陪阅读 436评论 0 0