浅谈iOS区块链项目的架构设计

前言

本文是对一个区块链交易所APP的简单分析,探索在区块链的背景下,交易所APP的设计有何特殊之处。

正文

业务场景和核心功能

交易所的核心场景有:

  • 行情查看 :实时同步最新的行情和资讯;
  • 交易操作 :数字货币的购买和卖出,操作记录同步;
  • 信息安全 :用户信息、账户资产信息的安全;
  • 交易安全 :身份确认和权限控制;

基于以上场景,看看实际的APP是如何设计。

架构分析

整个APP基于MVC的架构,特点如下:

1、网络层

HttpClient封装AFNetworking,定义统一的网络层操作; 使用AFNetworking的AFSecurityPolicy实现https的证书校验,读取本地bundle携带的证书后创建AFSecurityPolicy并赋值给AFHTTPRequestOperationManager; HttpClient大部分的回调使用Block进行处理,特殊的回调(比如状态同步)用NSNotification通知; 网络层和后台进行通讯都基于Json,再通过Runtime的方法把Json动态转化为本地Model; 通讯的方式以https为主,https的参数会增加一个字段,填写其他参数和本地固定值进行MD5的校验值,防止篡改; 少数实时性要求较强的页面使用WebSocket,可以减少网络消耗,提高通讯效率同时更不容易被劫持。

2、持久化

持久化有三种方式:KeyChain、CoreData、NSUserDefault,只有小部分数据存在KeyChain; APP需要持久化的数据不多,主要以用户的基本信息为主,行情动态、交易记录等实时拉取。

3、MVC

多数页面基于xib进行开发,页面的功能也比较清晰,多数为展示信息,少数需要进行交互; 有BaseVC无BaseView,BaseVC放置通用的逻辑,比如说获取用户信息、获取账户资产信息; 少数复杂页面通过代码进行开发,以K线图和各种交易指标视图为主。

4、质量相关

没有测试相关框架,也没有使用Xcode的单元测试、自动化测试,通过Debug/Release宏区分生产和开发环境,并增加一些专门用于Test的VC; 线上Crash跟进依赖Bugly库; 设备支持方面只有iPhone,且最低只支持iOS 9。

5、业务特性

权限分级,多重确认:只要登录即可查看行情和下订单,在支付相关场景根据支付额度和支付类型采取不同的验证手段(交易密码、手机验证、邮箱验证); 交易所不产生币,交易所只是币的搬运工: 在交易之前,需要把币打到交易所的账户,类似游戏厅的上分,之后可以再把分兑换成币。 OTC(场外交易):因为法律的原因,交易所不支持法币兑换(可选择交易所担保,由用户自行交易); 身份认证:出于反洗钱考虑,需要提供身份认证的功能; 状态同步:操作记录、用户信息、账户资产信息需要支持多设备同步;

总结

这个APP的开发难度系数:假设满分难度是5⭐️,平均难度是3⭐️,个人评估当前难度系数为 2⭐️,在持久化、MVC、质量这几点的设计我都不甚满意。 本想通过源码学习关于区块链交易和安全的知识,结果拨开神秘的面纱后,内心有所失望:没有找到那种让人惊艳的设计和代码,“签名、哈希、电子钱包、算法”这些概念都没有出现,只有赤裸裸的CRUD操作。 从该APP来看,APP客户端的职责只是Web功能的一个子集。但手机更容易识别用户身份以及方便携带,在安全性、便捷性上都优于PC,能做的事情理应不少于Web。 在区块链的热潮中,作为移动端能发出的光和热应该不仅仅这些,期待未来有机会接触到移动端进行链上操作的实现。

能力有限,如果错误请斧正。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Android 开发者

正式发布 Android 架构组件 1.0 稳定版

1082
来自专栏CSDN技术头条

GoSnaps:如何支持5天50万用户服务器只花100元

创业者们似乎有这样一个共识:初创公司应尽快推出MVP(最简可行产品)而不应该把扩展性这样的细节放在心上。总是有人给我说推产品是最高的也实际上是唯一的目标,扩展性...

18510
来自专栏维恩的派VNPIE

vn.py多账户交易系统配置思路

本文主要介绍了一个‘如何利用多个账号同时进行交易’的思路。感谢‘图扬量化’在「维恩的派」论坛内的分享!(下为原贴)

1173
来自专栏区块链入门

【链安科技】无限授权转账漏洞

Lightcoin 合约的 transferFrom() 函数,即授权转账函数,在执行完转账后本该修改授权金额,减去已转出部分金额。但这一步骤中把这授权账户地址...

552
来自专栏Jerry的SAP技术分享

SAP成都研究院大卫哥:SAP C4C中国本地化之微信小程序集成

今天的文章来自Wu David,SAP成都研究院C4C开发团队的架构师,在加入团队之前曾经在SAP上海研究院工作,组内同事习惯亲切地称呼他为大卫哥。

692
来自专栏量子位

想搞一套AI问答游戏系统?简单,Google又开源了

若朴 编译整理 量子位 出品 | 公众号 QbitAI 刚刚,Google开源了一套问答游戏App系统。 通过一套模板工具可以,你只要给出问题和答案,就能搞出一...

3555
来自专栏CSDN技术头条

说实话,分布式系统的复杂度远大于它的好处

最近,有一位酷酷的程序员小哥(由网站头像可得)在Hacker Noon网上发表了一篇名为《全面解析分布式系统》的文章。和以往烂大街的分布式教程不太一样,这位小哥...

922
来自专栏SAP最佳业务实践

从SAP最佳业务实践看企业管理(90)-PP-150生产转包

PP150生产转包 在制造过程中,当将生产的“计划订单”转换为“生产订单”时,系统会检查是否存在任何需要外部处理的工艺路线/工作中心工序。外部处理是一些工序或子...

2674
来自专栏nimomeng的自我进阶

《2016中国移动开发者大会》参会笔记

总的来说,2016年的综合场(第一天上午)感觉讲的一般,身边的人吐槽也比较多。不过相比之下,iOS场干货就比较多了,演讲者基本都是圈内大V,包括喵神,Sunny...

712
来自专栏编程

前端领域2017年有哪些变化,2018年又有怎样的期待?

以下为我在知乎问题「2017年前端有什么样变化?即将来临的2018有什么样的期待?」下的回答,稍作整理分享给大家。如有遗漏欢迎在评论中指出。原文如下: 在即将过...

28210

扫码关注云+社区