【HELLO WAKA】WAKA iOS客户端 之一 APP分析篇
由于后续篇幅比较大,所以调整了内容结构。
全系列
【HELLO WAKA】WAKA iOS客户端 之一 APP分析篇
【HELLO WAKA】WAKA iOS客户端 之二 架构设计与实现篇
【HELLO WAKA】WAKA iOS客户端 之三 创作模块分析与实现篇(上)
【HELLO WAKA】WAKA iOS客户端 之三 创作模块分析与实现篇(下)
【HELLO WAKA】WAKA iOS客户端 之四 服务器架构设计
MAKA 上周三发布了iOS客户端1.0。本着学习的态度,对MAKA客户端做了分析。
- 功能结构分解
- 架构分析
- API分析
- API数据结构分析
1. 功能结构分解
工具:iPhone,MindNode。
下图是概要的需求分析和功能分解。左边为需求,右边为根据需求实现的功能。
从需求角度和功能模块的实现来看,已经满足用户的最基本需求。
从产品策略来看,先解决有无问题,进而再持续改进。
2. 架构分析
完成了对需求和功能的分解后,我们再来看下APP与服务器的关系。这个时候,神器Charles就上场了。具体使用方式自行搜索。
通过抓取客户端与服务器通信数据分析,客户端与服务器的通信如下图。
1. API服务器。APP与服务器的主通信方式。使用RESTful + form风格接口。前置机为TNginx,后端接口为PHP。
2. 图片存储服务器。用于上传图片。可以注意到的是,采用原图上传 + 按需生成的方式。分离作品编辑和作品。好处有:1)图片数据单独处理,同时简化了客户端逻辑与服务器逻辑。2)方便后续变更。3)按需压缩裁剪图片,生成静态化作品,优化访问速度。
3. 作品浏览服务器。将作品静态化,优化服务器性能。
4. CDN。使用了七牛的图片CDN服务。
3. API分析
工具:Charles Proxy
以下是主要的API。
模块 |
名称 |
URL |
Method |
说明 |
用户 |
注册 |
/app/user/register |
POST |
|
登陆 |
/app/user/login |
POST |
||
忘记密码 |
/app/user/forgetpassword |
POST |
||
用户信息 |
/app/user/{$user_id} |
GET |
||
修改用户信息 |
/app/user/{$user_id} |
PUT |
||
事件 |
我的事件列表 |
/app/events |
GET |
|
创建 |
/app/event |
POST |
||
更新 |
/app/event/{$event_id} |
PUT |
||
发布 |
/app/event/{$event_id} |
POST |
||
创作 |
主分类 |
/app/specialCategories |
GET |
|
模板分类 |
/app/templates |
GET |
||
模板页 |
/app/template/{$template_id} |
GET |
||
图集分类 |
/app/pictureIndex |
GET |
||
图片列表 |
/app/pictures |
GET |
||
热门 |
公开事件 |
/app/publicEvents |
GET |
|
分类 |
/app/tagCategories |
GET |
1. 用户模块。基本用户接口。比较简单。登陆成功后使用token+uid访问接口。
2. 事件模块。 这部分接口页算简单。
1) 值得注意的是,作品列表数据,作品数据都采用了version号,模板与作品版本更新问题。
2) 模板与作品。 eg. GET /app/template/T_I1629HCW 直接使用在作品ID前加T_ 解决模板与作品的关系。
- {
- "id": "2BD324I1",
- "title": "我的测试项目",
- "content": "这是我的测试。",
- "thumb": "http:\/\/img1.maka.im\/6IAGSXT4R1S18SV2MP3O",
- "version": "1",
- "firstImg": "http:\/\/img1.maka.im\/575144\/1440766949nikIOQqegbRpr.jpeg",
- "template_id": "T_AHER10I9",
- "updateTime": "2015-08-28 11:11:11",
- "functionId": "0",
- "industryId": "0",
- "category_id": "10",
- "functionTag": "",
- "industryTag": "",
- "statData": 0,
- "statUrl": "http:\/\/api.maka.im\/statistics\/show\/2BD324I1",
- "formData": 0,
- "hasForm": 0,
- "formUrl": "",
- "QRcodeImg": "http:\/\/api.maka.im\/code\/index\/2BD324I1"
- }
3. 创作模块。这里没有太多好讲的。基本数据返回。比较赞的是,返回云图册,手机端可以访问PC端上传的图片。
4. 热门模块。简单API。
4. 总结
1. 服务器架构。分离接口访问,作品查看,图片处理,图片存储,CDN。各个服务器都可以进行横向扩展并且单独优化。
2. 客户端架构。
1)第三方库依赖管理。使用Cocoapods管理第三方库。
2)网络库。没有使用AFNetworking,可能是直接使用iOS内置类处理。这个比较意外。
3)数据库。使用FMDB。
4)缓存。SDWebImage。
5)框架。使用ReactiveCocoa,Masonry。
6)其他。其他的一些UI库。
7)不使用Storyboard和xib。
以上,是MAKA iOS的需求和功能分析,以及技术分析。
备注:纯属学习。请勿跨省。
【HELLO WAKA】WAKA iOS客户端 之一 APP分析篇的更多相关文章
- 【HELLO WAKA】WAKA iOS客户端 之二 架构设计与实现篇
上一篇主要做了MAKA APP的需求分析,功能结构分解,架构分析,API分析,API数据结构分析. 这篇主要讲如何从零做iOS应用架构. 全系列 [HELLO WAKA]WAKA iOS客户端 之一 ...
- “快的打车”创始人陈伟星的新项目招人啦,高薪急招Java服务端/Android/Ios 客户端研发工程师/ mysql DBA/ app市场推广专家,欢迎大家加入我们的团队! - V2EX
"快的打车"创始人陈伟星的新项目招人啦,高薪急招Java服务端/Android/Ios 客户端研发工程师/ mysql DBA/ app市场推广专家,欢迎大家加入我们的团队! - ...
- 开源项目在真机调试(Coding iOS 客户端为例)
一.前言 iOS 13学习系列:如何在github下载开源项目到本地(Coding iOS 客户端为例)已经把 Coding iOS 客户端源码下载到本地. 但项目进行真机调试遇到很多问题. 二.问题 ...
- iOS客户端的在线安装和更新——针对ADHoc证书
这篇文章纯给自己留个备份,所以对AdHoc证书内部分发和对iOS客户端开发不了解的请直接无视. 一般在iOS游戏或应用开发过程中,正式发布到App Store之前,都需要内部的测试,客户端的安装是个不 ...
- 新浪微博iOS客户端架构与优化之路
新浪微博iOS客户端架构与优化之路 随着Facebook.Twitter.微博的崛起,向UGC.PGC.OGC,自媒体提供平台的内 容消费型App逐渐形成了独特的客户端架构模式.与电商和通讯工具类 ...
- iOS应用架构现状分析
iOS从2007年诞生至今已有近10年的历史,10年的时间对iOS技术圈来说足够产生相当可观的沉淀,尤其这几年的技术分享氛围无论国内国外都显得异常活跃.本文就iOS架构这一主题,结合开发圈里讨论较多的 ...
- Nice是如何做iOS客户端架构的?
一个创业产品的iOS客户端架构到底怎么做呢?现下最有活力的图片社交软件Nice的技术负责人刘诗彬将为我们解答创业产品如何实现iOS客户端架构. 分享人:刘诗彬,毕业于北京邮电大学电子信息科学与技术专业 ...
- 精华阅读第 9 期 |滴滴出行 iOS 客户端架构演进之路
「架构都是演变出来的,没有最好的架构,只有最合适的架构!」最近,滴滴出行平台产品中心 iOS 技术负责人李贤辉接受了 infoQ 的采访,阐述了滴滴的 iOS 客户端架构模式与演变过程.李贤辉也是移动 ...
- 开源中国iOS客户端学习
开源中国iOS客户端学习 续写前言 <开源中国iOS客户端学习>续写前系列博客 http://blog.csdn.net/column/details/xfzl-kykhd.html ...
随机推荐
- anadonca环境配置和模块安装
1.最方便的python环境配置: 下载anaconda即可,自带spyder,集成科学计算的库,自带pip,不用折腾. 想用sublime编写python并运行的话,需要自己配置编译环境,并下载插件 ...
- HttpContext.Current.Request.ServerVariables
Request.ServerVariables("Url") 返回服务器地址Value 0: /WebSite1/Default.aspx Request.ServerVariab ...
- TypeScript开发ReactNative之fetch函数的提示问题
使用TypeScript开发ReactNative时,发现在类中调用 fetch 函数时IDE可能会提示找不到,无法加载,特别是当类中存在同名的 fetch 成员方法时更是郁闷了,虽然程序是可以执行的 ...
- win7无声音显示“未插入扬声器或耳机” 怎么解决
不知道是否有用户朋友跟本人遇到这么一个情况,电脑不论是不是有插上耳机或者扬声器,在机箱前面和后面的耳机插孔处都试了好几遍,win8纯净版系统依旧没有声音. 这时候我们来看一下桌面右下角音量图标显示一个 ...
- [Angular Directive] Implement Structural Directive Data Binding with Context in Angular
Just like in *ngFor, you're able to pass in data into your own structural directives. This is done b ...
- Intellij Idea + Maven + Git + Struts2 HelloWorld
1.在intellij Idea上新建Maven项目,输入相应的groupId,artifactId,项目名称: 2.在项目的pom文件中,引入struts2的核心依赖struts2-core: &l ...
- Tomcat启动极慢问题
启动后,catalina.out日志中会有如下打印: INFO: Creation of SecureRandom instance ,] milliseconds 具体原因,有兴趣的可以自己百度一下 ...
- C#中的重写和覆盖的区别
#中重写(override)和覆盖(new)的区别 重写用关键字 virtual 修饰的方法,叫虚方法.可以在子类中用override 声明同名的方法,这叫“重写”.相应的没有用virtual修饰的方 ...
- Scala Singleton对象
Scala Object: scala没有静态的修饰符,例如Java中的static.但是Scala提供了Object类型,object下的成员都是静态的,比较像Java的静态类.不同在于Scala的 ...
- 【IE6的疯狂之十二】一个display:none引起的3像素的BUG
今天同事给我看了一个display:none引起的3像素的BUG,非常奇怪!从来没碰到过display:none还能引起这种bug. 看代码: <div style="width: ...