Mixin Messenger 早期采用 FMDB 后来切换至 WCDB 沿用至今,一直比较可靠稳定,这里分享一下使用心得和功能扩展。ios
Mixin Messenger 是一个开源的端对端加密聊天软件,而且集成基于 Mixin Network 的多链钱包。git
官网下载:https://mixin.one/messenger
开源地址:https://github.com/MixinMessenger/ios-appgithub
WCDB Swift 是一个易用、高效、完整的移动数据库框架,基于 SQLite 和 SQLCipher 开发。sql
开源地址:https://github.com/Tencent/wcdb/数据库
fork 代码开源地址:https://github.com/MixinNetwork/wcdb,注意使用 xcode10.2+swift4.2 分支代码。swift
WINQ 语言集成查询适用于简单的增删改查,可是对于很是复杂的 SQL 语句,用 WINQ 拼出来且不说代码很是多 — — 可读性和可移植性很是差,搞不懂官方为何不支持一下。大致上读了一下源码可知 WINQ 也是拼 SQL 语句,因为库做用域限制,只好 fork 一份改源码:xcode
// 带参数查询 database.prepareSelectSQL(User.Properties.Id, "SELECT id FROM users where id = ?", values: ["1"]) // 带参数 LIKE 查询 database.prepareSelectSQL(User.Properties.Id, "SELECT id FROM users where name like ?", values: ["%candy%"]) // 带参数更新 let updateSQL = try database.prepareUpdateSQL(sql: "UPDATE conversations SET last_message_id = (select id from messages where conversation_id = ? order by created_at DESC limit 1) WHERE conversation_id = ?") try updateSQL.execute(with: [conversationId, conversationId])
须要特别注意的是若是返回 Codable 数据,SELECT 字段的顺序必需要和 CodingKeys 里的顺序一致,不然数据会填充乱,用 WINQ 不会有这个问题。安全
与微信、QQ、Telegram 不一样,Mixin Messenger 是端对端加密服务器不存消息,使得消息备份功能必须须要依赖客户端来完成,WCDB 没有这个需求因此不支持,能够经过扩展 SQLite 直接支持:服务器
参考 https://github.com/MixinNetwork/wcdb/commit/83416a270116fe97fc5f8873d0ad5686a24964db 修改记录便可支持备份功能,还支持进度回调微信
try database.backup(withFile: path) { (remaining, pagecount) in // progress = Float(pagecount - remaining) / Float(pagecount) }
官方文档:关于 WCDB Swift
Mixin是如何实现匿名交易的?
总体来讲仍是比较好用,关键是可靠,并且 Swift 支持的比较好,Codable 支持得也很赞,欢迎交流使用经验,个人 Mixin ID:762532。