App的开发无外乎从网络端获取数据显示在屏幕上,数据做些缓存或者持久化,所以网络层极为重要。原来只是把AFNetwork二次封装了一下,使得调用变得很简单,并没有深层次的考虑一些问题。

前言

参考:

网络层设计方案

这篇文章提的问题也正是我平时经常纠结的,但是一直没有深入思考。文章给的解决方案和为什么这样做让人茅塞顿开。以下主要就是我的观后感。

三个问题

  • 使用哪种交互模式来跟业务层做对接?
  • 是否有必要将API返回的数据封装成对象然后再交付给业务层?
  • 使用集约化调用方式还是离散型调用方式去调用API?

我的设计

基本上每个网络层都会涉及到这三个问题。

我原先的设计是:

//APIClient.h
@interface APIClient : AFHTTPSessionManager + (instancetype)sharedRequestDataClient; /*
* 用json格式(POST)
*/
+ (void)requestDataPostMethodWithHTTPPath:(NSString *)path
parameters:(NSDictionary *)parameters
success:(RequestSuccessBlock)success
failure:(RequestFailureBlock)failure;
/*
* 用json格式(GET)
*/
+ (void)requestDataGetMethodWithHTTPPath:(NSString *)path
parameters:(NSDictionary *)parameters
success:(RequestSuccessBlock)success
failure:(RequestFailureBlock)failure; @end //APIManager.h(一个个具体的请求,有多少个请求就有多少个方法)
@interface APIManager : NSObject /**
* 获取用户信息
*/
+ (void)requestUserInfoWithSuccess:(RequestSuccessBlock)success failure:(RequestFailureBlock)failure; ...
@end @implementation APIManager /**
* 获取用户信息
*/
+ (void)requestUserInfoWithSuccess:(RequestSuccessBlock)success
failure:(RequestFailureBlock)failure {
[APIClient requestDataGetMethodWithHTTPPath:kUserInfo parameters:nil success:success failure:failure];
} ...
@end

APIClient继承AFHTTPSessionManager,里面做了些设置,比方说统一用json,就两个方法,get,post请求。

本来还有上传下载数据两个方法,后来所有的资源文件放阿里云上,重建了个APIOSSClient类来处理。

APIManager具体处理一个个请求,有多少请求,他就有多少方法。由它来调用APIClient。

我的回答

  • 数据的传递方式:Block。
  • 交付什么样的数据:NSDictionary,在Block回调里把字典处理成最终需要的数据,大多数情况下是model,在model里会有数据处理。
  • APIClient是集约型,很不方便,加了个APIManager,实现离散型的调用,也就是加了个离散型调用的壳。

作者的建议

  • 数据的传递方式:Delegate。
  • 交付什么样的数据:不作处理,添加了reformer(名字而已,叫什么都好),用于封装数据转化的逻辑。
  • 离散型的API调用方式。

感想

看了作者的思路和源码,发现作者考虑的问题也都想到了,但是处理的方式有很大的问题。

传递方式和调用方式

最早我接手项目的时候,只有APIClient,简单地做AFNetwork做了封装,属于集约型API调用方式,用block回调是正常的。

后来发现集约型API调用方式的弊端太多了,于是我加了个APIManager,规定所有的请求必须在里面加个方法,算是加了个离散调用的壳。但是最后APIManager太大了,好多方法,维护起来好累。

所以调用的方式还是离散型的好,因为是离散型的,所有Delegate比Block好。

作者一个API对应于一个APIManager,更加容易维护。好处非常多。

传递数据

对于应该传什么数据,其实我们的理想情况是希望API的数据下发之后就能够直接被View所展示。首先要说的是,这种情况非常少。另外,这种做法使得View和API联系紧密,也是我们不希望发生的。

这是作者的想法,我们也发现了这个问题,所以会单独在写个类处理,或者转成model,在model里处理,最终变成view需要的数据。如果是model,为了不让view和model耦合,又加了个category传数据。

而作者加了个reformer统一处理,并且作者强调去model化,从根源解决了转化成本高,model和view耦合等问题。

细节就不讲了,作者开源的网络层很cool,除了使用起来非常方便,功能还非常全,全方面覆盖。小伙伴们自己去学习吧。

iOS网络层设计感想的更多相关文章

  1. 设计人员应该看的15个很酷的 iOS 8 设计

    苹果新一代智能手机 iPhone 6 发布已经有一段时间了,一些创意设计师已经开始在设计中采用 iOS 8 设计理念.当然,其中有些是对于未来的展望和大胆的设计.我在这里收集了15个很酷的 iOS 8 ...

  2. Swift 轻量级网络层设计

    前言 普遍我们的网络层设计的时候直接是如下结构APIManager.post(url, parameter,completeHandle),服务器配置在APIManager.m文件中进行配置.这样一个 ...

  3. iOS界面设计,12个优秀案例激发你的灵感

    总所周知,iOS和Android是当今两大移动平台,前者采用Human Interface Design,后者采用Material Design.作为设计师,尤其是App设计师,总是会在这两者进行设计 ...

  4. iOS界面设计之基础控件的学习 --- UITextField

    学习iOS界面设计也有段时间了,每次写到一些基础控件(如:UILable . UITextField)的时候就深觉应该总结一个函数来实现这些基础控件的属性设置,所以下面就是我对UITextField的 ...

  5. ios的设计原则

    ios的设计原则 iOS设计的详细的主要宗旨例如以下: 1.易操作,所关心的主题清新 2.UI控件布局合理,图片质量清新 3.用户的使用习惯 4.字体的大小,主次分明 5.舒适的动画效果 在创建一个新 ...

  6. iOS界面设计切图小结

    iOS界面设计切图小结 APR 12TH, 2013 1.基本尺寸 (1)界面 实际设计时按: iPhone4.4s:640px*960px iPhone5: 640px*1136px iPad:15 ...

  7. iOS的设计备忘录/资源集合(新手快速开发)

    iOS的设计备忘录 随着iOS7更新,风格走上扁平化,大部分iOS设计师及程序员都需要对自己的软件做相关调整,尺寸.Icon.UI等等,我在这里总结一下相关资料,以及提供一些关于iOS7设计素材. 一 ...

  8. HNU_团队项目_数据库设计感想_个人感想

    数据库设计感想  个人的一点心得体会 最重要的放在最前面——讨论开会时的123经验 开会前对会议目的及方式要有所考虑: 不要随意无目的开会: 遵守时间,控制会议时间长度: 会议主持人要维持会议只需,有 ...

  9. iOS网络层架构设计分享

    前言 前些天帮公司做了网络层的重构,当时就想做好了就分享给大家,后来接着做了新版本的需求,现在才有时间整理一下. 之前的网络层使用的是直接拖拽导入项目的方式导入了AF,然后还修改了大量的源码,时隔2年 ...

随机推荐

  1. Myeclipse创建新项目

    1. 打开myeclipse, 配置mysql server preference里找到 show view-- DB Browser, 新建数据库驱动. 1. URL填写: jdbc:mysql:/ ...

  2. ibatis一对多 数据库设计及实现

    iBatis的多表关联. ibatis的表关联,和数据库语句无关,是在Java程序中,把若干语句的结果关联到一起.这种关联形式,虽然在大数据量时是很奢侈的行为,但是看起来很干净,用起来也很方便. 这里 ...

  3. 《数据结构与算法分析:C语言描述》读书笔记------List的C语言实现

    List的简单实现.在GCC下测试通过. list.h #ifndef _List_H /*List数据结构的简单实现*/ struct Node; typedef struct Node Node; ...

  4. 以太网数据包、IP包、TCP/UDP 包的结构(转)

    源:以太网数据包.IP包.TCP/UDP 包的结构 版本号(Version):长度4比特.标识目前采用的IP协议的版本号.一般的值为0100(IPv4),0110(IPv6). IP包头长度(Head ...

  5. BZOJ 2705 [SDOI2012]Longge的问题 ——Dirichlet积

    [题目分析] 狄利克雷卷积. 然后直接求出欧拉函数,计算和即可. [代码] #include <cstdio> #include <cstring> #include < ...

  6. IOS9新特性之Contacts联系人

    在以前iOS开发中,涉及联系人相关的编程,代码都非常繁琐,并且框架的设计也不是Objective-C风格的,这使开发者用起来非常的难受.在iOS9中,apple终于解决了这个问题,全新的Contact ...

  7. BZOJ3270: 博物馆

    3270: 博物馆 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 269  Solved: 147[Submit][Status][Discuss] ...

  8. 安卓Visibility属性

    可见(visible) XML文件:android:visibility="visible" Java代码:view.setVisibility(View.VISIBLE); 不可 ...

  9. scala系列--基础语法

    Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 区分大小写 -  Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义. 类 ...

  10. 使用PopupMenu创建弹出式菜单

    PopupMenu代表弹出式菜单,它会在指定组件上弹出PopupMenu,默认情况下,PopupMenu会显示在该组件的下方或上方.PopupMenu可增加多个菜单项,并可为菜单项增加子菜单. 使用P ...