我和SqlCipher和Akavache在iOS上有个问题。当我使用SqlCipher的现有实现将Akavache库添加到我的项目中时,我在链接期间会得到许多重复的sqlite错误。
当前的行为是什么?
当我使用Link程序集构建iOS时,我会收到以下Sqlite链接误差
如果当前行为是错误的,请提供重现的步骤,如果可能的话,请提供问题的最小演示。
,预期的行为是什么?,Akavache,Sqlite和SqlCipher,Sqlite就是一起工作的。
哪个版本的Akavache,以及哪个平台/操作系统受到这个问题的影响?这在Akavache的早期版本中有效吗?
我也不知道。SqlCipher是在几个月前实现的,我们现在正在将Akavache添加到该项目中。
其他信息(例如堆栈跟踪、相关问题、修复建议)
在我走上维护岔路口的道路之前,我想知道是否有更好的方法?
发布于 2017-06-16 21:28:21
实际上,您要做的是将包含自定义SQLite构建的Akavache添加到已经包含自定义SQLite构建的应用程序中。由于iOS链接的方式,这是一个问题。
我怀疑你真的需要一个“叉子”的阿卡瓦奇。海事组织,您真正需要的是Batteries_V2.Init()的实现,它与应用程序中已有的SQLCipher实例进行对话。
这是可行的,因为SQLitePCL.raw已经包含了这个"bundle“概念的多个实现,并且使用诱饵和切换从一个转换到另一个。
您的问题相当于我不时得到的一个问题:“如何使用自定义SQLite构建SQLitePCL.raw?”在你的情况唯一的区别是,你已经有这样一个定制的构建作为你的应用程序的一部分。无论如何,这是相似的,不幸的是,SQLitePCL.raw并没有让这件事变得像它应该的那样简单。
无论如何,解释如何弥合Akavache与您现有的SQLCipher构建之间的差距可能超出了这个答案的范围,但我可能能够帮助您朝着正确的方向前进。你可以在https://github.com/ericsink/SQLitePCL.raw上发布一个问题,我会看到的。
发布于 2017-06-16 21:23:39
我对将密码支持添加到Akavache方面兴趣不大。如果你能找到一种不可怕的方法去做,那么在GitHub上为其他人发布它。Akavache已经通过http://kent-boogaart.com/blog/password-protected-encryption-provider-for-akavache拥有一个加密API。
值得关注的是,Sqlite的作者建议删除这一行,因为这意味着您还会遇到更大的Sqlite生态系统(包括蔚蓝移动服务)的问题。
https://stackoverflow.com/questions/44592767
复制相似问题