简介:
很多人在进行网络请求的时候,都是直接请求网络数据,然后每次都自己手动解析数据,判断接口类别,然后再进行下一个步骤,但是其实请求网络数据有很多共性的东西,例如存储请求参数的统一性、后台返回的数据类型统一性、sessionId 过期处理统一性等。
(总结《App研发录》第二章(Android 网络底层框架设计))
目录:
1.网络底层封装
2.App 数据缓存设计
3.用户登录
4.HTTP 头中的奥妙
网络底层封装
网路请求格式
Request 格式
网络请求一般具有 POST 、GET 方式:
- POST 方式是把 key-value 这样的键值对存放在 Form 表单中。
- GET 方式是把 key-value 这样的键值对存放在 URL 上。
其实无论是哪种方式,都需要 key-value 的方式,因此,在传参数给网络请求框架的时候,都可以以 Map 的形式,然后网络请求框架再依据请求方式,把 Map 里面的数据取出来,放入相应的位置即可。
Response 格式
后台返回数据格式一般为 JSON,可以与后台协商返回固定格式的 JSON,例如所有的 JSON 都返回 isError、errorType、errorMessage、result 四个字段,它们的意思分别为:
- isError:请求网络数据成功与否。
- errorType:错误类型。
- errorMessage:错误消息。
- result:请求成功的时候返回的数据结果
AsyncTask 的使用和缺点
- 将 AsyncTask 封装在 AndroidLib 类库中。
- 对于网络错误进行处理。例如:
- SessionId 过期时,提示用户重新登录
- 无网络时,提示用户检查数据连接情况
- 服务器无响应的时候,提示服务器正在维护
- 开发者在请求网络框架时,不该处理这么多错误或成功判断,而是应该直接重写 onSuccess 和 onFail 两个回调函数即可。
- AsyncTask 无取消请求的方法,一旦请求后,就不会被取消,导致资源过度浪费并使得迫切请求的接口无法排上队列,无法进行处理。
网络底层的一些优化工作
- 使用 onFail 的统一处理机制,对于常见的问题进行处理。
- 将存放 url 文件的数据一次性全部读取处理,并且放到内存中方便之后进行访问,若内存被回收,则重新读取。
- 不是每个请求都需要回调。
- ProgressBar 的处理。在请求数据的时候,显示进度条,直到有结果返回的时候才将进度条隐藏。进度的样式需要整个 App 风格统一。
App 数据缓存设计
数据缓存策略
- 减少网络获取数据次数:
- 原本需要从 3 个接口中获取数据,可以制作一个新的接口,一次性获取这些数据。
- 调用完一次 GET 方式的接口,在一段时间内不能再调用。
- 将 GET 方式的接口数据缓存到本地中,无网络的时候进行获取返回。
强制更新
由于我们使用了数据缓存策略,导致一段时间内的数据不会再进行更新,这时,应该提供一个按钮让用户决定是否强制更新该页面中的数据。
用户登录
自动登录
- 不可将账户密码保存到本地数据中,应使用 Cookie 进行判断是否需要登录。
- 当 Cookie 过期的时候,无论用户身处哪个页面,都必须弹出框,提示用户“Cookie 过期,请重新登录”。
- 为了防止刷库。当发现同一 IP 短时间内频繁访问某个接口的时候,就需要进行拦截,让其进行手动验证才能进行继续访问。
HTTP 头中的奥妙
时间校准
HTTP Response 头中具有一个重要属性——Date,该属性记录了当时的服务器时间。由于部分 App 的本地时间不准确,因此,需要把服务器时间与本地时间进行相减,得到一个差值保存起来,之后读取本地时间的时候,加上该差值,则是服务器时间。
开启 gzip 压缩
当数据返回的量太大的时候,需要开启 gzip 压缩:
- 减少存储空间
- 减少传输的时间
若已开启 gzip 压缩,在获取接口的数据的时候,需要把数据解压后再进行处理。