• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - iOS 上的 SQLite + SQLCipher + FMDatabase

[复制链接]
菜鸟教程小白 发表于 2022-12-13 13:07:25 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我目前在我的 iOS 应用程序中使用 FMDatabase,我对此非常满意。 我打算用 SQLCipher 加密 sqlite 数据库。

这是我的问题:

1) FMDatabase 和 SQLCipher 是否兼容?我想我只需要在 FMDatabase 中添加一个名为 openEncrypted 的新方法……然后为 SQLCipher 完成这项工作。我希望所有 FMDatabase 方法都能正常工作。

2) 实际上,我的应用中有 2 个数据库。然后我在我的应用程序中做一个 ATTACH DATABASE 来加入他们。我只想加密两者之一。它会起作用还是我需要加密 2 个数据库? (一个很关键,另一个不是)

3) 如果我加密这些文件,我真的不明白我必须向 Apple 提供什么(文档)。

谢谢!



Best Answer-推荐答案


对于那些正在寻找有关如何完成此操作的简单教程的人,我能够创建一个:http://www.guilmo.com/fmdb-with-sqlcipher-tutorial/

但最重要的部分是,打开您现有的数据库并附加一个新的加密数据库。然后在您的 FMDB 连接中设置 key 。

SQLCipher - 加密数据库

// Import sqlite3.h in your AppDelegate
#import <sqlite3.h>

// Set the new encrypted database path to be in the Documents Folder
NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentDir = [documentPaths objectAtIndex:0];
NSString *ecDB = [documentDir stringByAppendingPathComponent"encrypted.sqlite"];

// SQL Query. NOTE THAT DATABASE IS THE FULL PATH NOT ONLY THE NAME
const char* sqlQ = [[NSString stringWithFormat"ATTACH DATABASE '%@' AS encrypted KEY 'secretKey';",ecDB] UTF8String];

sqlite3 *unencrypted_DB;    
if (sqlite3_open([self.databasePath UTF8String], &unencrypted_DB) == SQLITE_OK) {

    // Attach empty encrypted database to unencrypted database
    sqlite3_exec(unencrypted_DB, sqlQ, NULL, NULL, NULL);

    // export database
    sqlite3_exec(unencrypted_DB, "SELECT sqlcipher_export('encrypted');", NULL, NULL, NULL);

    // Detach encrypted database
    sqlite3_exec(unencrypted_DB, "DETACH DATABASE encrypted;", NULL, NULL, NULL);

    sqlite3_close(unencrypted_DB);
}
else {
    sqlite3_close(unencrypted_DB);
    NSAssert1(NO, @"Failed to open database with message '%s'.", sqlite3_errmsg(unencrypted_DB));
}

self.databasePath = [documentDir stringByAppendingPathComponent"encrypted.sqlite"];

请注意,我们在 SQL Query 中设置了 2 个参数,DATABASE 和 KEY。 DATABASE 应该是您要创建的加密数据库的完整路径,在本例中为字符串 ecDB,KEY 参数是用于加密您的数据库的 key ,因此请选择强者

现在在您的 FMDB 函数上,每次打开数据库后调用 [db setKey"strongKey"]

// FMDatabase Example
FMDatabase *db = [FMDatabase databaseWithPath:[self getDatabasePath]];
[db open];
[db setKey"secretKey"];


// FMDatabaseQueue Exmple
FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[self getDatabasePath]];

[queue inDatabase:^(FMDatabase *db) {
    [db setKey"secretKey"];
    ...
}];

如果您有任何问题,请告诉我!

关于ios - iOS 上的 SQLite + SQLCipher + FMDatabase,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10106565/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap