2023-02-03

<meta charset="utf-8">

框架简介

Lotus 网络库基于 Retrofit 进行封装,Retrofit是Square公司开源的网络框架,底层是基于 OkHttp 实现的,不过相比 OkHttp 使用更方便,更适合进行 RESTful API 格式的请求。

网络库内部实现了 Lotus 双向认证功能,可以在初始化的时候选择是否开启双向认证,框架会自动切换对应的url,业务方无需关注和服务端的认证细节。

快速上手

网络库中默认打开了双向认证,并根据双向认证开关配置了相应的 baseUrl,大多数场景下只需要控制双向认证开关,其余配置走默认即可。

  1. 初始化

在发起网络请求之前(建议在ApplicationonCreate()中),调用:

RetrofitController.init(application, enableMutualAuth)

  • application:Application类型,传入当前App的Application实例

  • enableMutualAuth:Boolean类型,双向认证开关

在调用了init之后就完成了初始化工作,内部包含了双向认证、网络状态、本地网络缓存等等功能,所有的网络请求都需要在初始化之后发起。

  1. 定义数据 Model

在请求之前需要根据接口协议的字段定义对应的数据Model,用来做Request或者Request的body。

比如我们需要通过UserId获取对应用户的UserName

  1. 定义 Request 数据 Model

后端请求接口参数如下:

{
    "userId" : "123456"
}

那么根据参数定义一个UserNameReq类:

data class UserNameReq(
    /** 用户id */
    var userId: String
)
  1. 定义 Response 数据 Model

后端返回数据如下:

{
    "userName" : "MC"
}

对应定义一个UserNameReq:

data class UserNameRsp(
    /** 用户id */
    var userId: String
)
  1. 编写 Http 接口

用注解的形式标注 Http 方法,然后参数传入 http 请求的 url:

/** 获取用户ID */
@POST("api/cloudxcar/atmos/v1/getName")
suspend fun getUserName(@Body request: UserNameReqesponseEntity<UserNameRsp>

返回是一个 Response 实体,内部包含服务端的返回码、提示信息及返回数据。

  1. 实现具体请求类

suspend fun getUserName(userId: String = ""): ResponseEntity<UserNameRsp> {
    val responseEntity = withTimeoutOrNull(TIME_OUT) {
        withContext(Dispatchers.IO) {
            RetrofitController.client.getUserName(
                UserNameReq(userId)
            )
        }
    }
    return responseEntity
}

请求类主要做的事就是调用网络接口,然后返回响应实体

  1. 发起请求并处理返回结果

网络库定义了一个顶层函数用来发起请求并接收返回结果或处理异常:

fun <reified T> httpRequest(block, fail, error, cacheKey): T?

  • block:实际请求体,必填。可以传入步骤 4 中实现的接口

  • fail:请求错误回调,非必填。用来处理服务端返回的请求错误,会携带错误码及错误信息

  • error:请求异常回调,非必填。用来处理请求中发生的异常,此时没有response返回

  • cacheKey:数据缓存唯一标识,非必填

httpRequest 中的泛型 T 就是步骤2定义的 Response 实体,正常返回会在方法内部自动解析出 UserNameRsp,到此就完成了一次网络请求。

设置配置项

  1. 设置双向认证开关

在初始化的时候控制双向认证开关:

fun init(context: Application, needMutualAuth: Boolean = true)

方法内部会根据开关值来切换不同的后端服务器

  1. 替换 BaseUrl

在网络库内部预置了 Lotus 的后端Host地址:

https://scc-api-uat.lotuscars.com.cn/

https://scc-uat.lotuscars.com.cn

两个分别对应带双向认证的接口和不带双向认证的接口,大多数App可以直接使用这两个 host 作为BaseUrl 完成网络请求。

网络库内部封装了一个 OKHttp client,默认使用了以上 url 作为 BaseUrl,同时网络库支持配置自定义的 BaseUrl,可使用以下接口重新获取一个新的Client:

fun obtainClient(baseUrl: String, mutualAuthenticate: Boolean = true): ServerApi 

传入自定义 BaseUrl 及双向认证开关即可,后续网络请求使用新的Client即可。

  1. 数据缓存

在前面发起请求调用httpRequest顶层函数的时候,可以传入一个可选参数cacheKey,这个key不为空则网络库会在本地保存当前请求的返回数据。Key作为缓存的唯一标识,在无网络或请求失败的时候,会通知调用方错误,并返回缓存的数据。

缓存部分流程如下:


image.png
  1. 错误及异常处理

在发起请求的顶层函数 httpRequest 中,有两个参数用来提供给调用方处理错误和异常。

首先区分一下错误和异常:

错误通常是发起了网络请求,且网络请求有响应,只是由于接口地址或者参数等等原因导致服务端解析失败,最终返回错误码及错误信息。

而异常是指在发起网络请求的过程中出现了 Exception,导致整个网络请求流程被中断,所以当异常发生的时候,网络库是不会返回错误码和错误信息的,只能返回异常信息供调用方定位问题。

回调的使用方式很简单,只需要在httpRequest中传入两个回调:failerror,下面分别看看二者的处理方式:

  1. 错误处理

fai的定义如下:

fail: (response: ResponseEntity<T>) -> Unit = {
    onFail(it)
}

传入的回调有一个 ResponseEntity 参数,这是网络请求返回的响应实体,内部包含errorCodeerrorMessage,不传则默认打印这两个字段,可以在 Logcat 中通过Tag:Http Request过滤出来。

  1. 异常处理

error的定义如下:

error: (e: Exception) -> Unit = {
    onError(it)
},

回调函数只有一个 Exeption 对象,和前面的定义相符,在异常的时候将异常返回供调用方定位问题。不传网络库默认打印异常,可以在 Logcat 中通过Tag:Http Request过滤出来。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,458评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,454评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,171评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,062评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,440评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,661评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,906评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,609评论 0 200
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,379评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,600评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,085评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,409评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,072评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,088评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,860评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,704评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,608评论 2 270

推荐阅读更多精彩内容

  • 上诉 当事人对一审法院作出的判决,以及不予受理、管辖权异议和驳回起诉的裁定,有权提起上诉。当事人对已经发生法律效力...
    东方有巢氏阅读 61评论 0 0
  • 审判监督程序 当事人认为人民法院作出的生效判决、裁定错误的,有权在判决、裁定发生法律效力后6个月内申请再审。以下四...
    东方有巢氏阅读 52评论 0 0
  • 今天妈妈在手机上看了一条视频,视频上,一个女孩的手机掉到铁,他非常的着急警察得知此消息后,在海边叫了一声小布...
    灵丹妮妮阅读 214评论 0 0
  • 身体很重要,快乐很重要,这才叫人间。这是平凡人的世界,平凡人的体悟。烟火人间,不能避免。 (二) ...
    许生说阅读 86评论 0 1
  • 所谓复杂,关键是复杂需要如何写。 复杂因何而发生? 了解清楚复杂到底是一种怎么样的存在,是解决一切问题的关键。 普...
    世界大文史阅读 108评论 0 1