Browse Source

doc: default-converter.md

drake 2 years ago
parent
commit
6350f48d52
2 changed files with 49 additions and 2 deletions
  1. 46 0
      docs/default-converter.md
  2. 3 2
      mkdocs.yml

+ 46 - 0
docs/default-converter.md

@@ -0,0 +1,46 @@
+Net支持请求返回的数据类型取决于你的转换器(即理论上支持返回任何数据对象), 默认情况下支持返回以下数据类型
+
+| 函数 | 描述 |
+|-|-|
+| String | 字符串 |
+| ByteArray | 字节数组 |
+| ByteString | 内部定义的一种字符串对象 |
+| File | 文件对象, 这种情况其实应当称为[下载文件](download-file.md) |
+| Response | 最基础的, 包含全部响应信息的对象(响应体/响应头/请求信息等) |
+
+使用示例
+
+```kotlin
+scopeNetLife {
+    Get<Response>("api").await().headers("响应头名称") // 返回响应头
+}
+```
+
+??? summary "默认使用的是: [NetConverter.DEFAULT](https://github.com/liangjingkanji/Net/blob/master/net/src/main/java/com/drake/net/convert/NetConverter.kt)"
+    ```kotlin
+    interface NetConverter {
+
+        @Throws(Throwable::class)
+        fun <R> onConvert(succeed: Type, response: Response): R?
+
+        companion object DEFAULT : NetConverter {
+            /**
+             * 返回结果应当等于泛型对象, 可空
+             * @param succeed 请求要求返回的泛型类型
+             * @param response 请求响应对象
+             */
+            override fun <R> onConvert(succeed: Type, response: Response): R? {
+                return when {
+                    succeed === String::class.java && response.isSuccessful -> response.body?.string() as R
+                    succeed === ByteString::class.java && response.isSuccessful -> response.body?.byteString() as R
+                    succeed is GenericArrayType && succeed.genericComponentType === Byte::class.java && response.isSuccessful -> response.body?.bytes() as R
+                    succeed === File::class.java && response.isSuccessful -> response.file() as R
+                    succeed === Response::class.java -> response as R
+                    else -> throw ConvertException(response, "An exception occurred while converting the NetConverter.DEFAULT")
+                }
+            }
+        }
+    }
+    ```
+
+假设这里没有你需要的数据类型请[自定义转换器](/converter/#_3)(例如返回Json或Protocol)

+ 3 - 2
mkdocs.yml

@@ -40,8 +40,9 @@ nav:
   - 同步请求: sync-request.md
   - 请求参数: request.md
   - 全局配置: config.md
-  - 返回数据:
-      - 使用转换器: converter.md
+  - 响应数据:
+      - 默认转换器: default-converter.md
+      - 自定义转换器: converter.md
       - 特殊结构解析: convert-special.md
       - kotlin-serialization: kotlin-serialization.md
       - 数据模型生成插件: model-generate.md