From afbcede8a1209f35da760667ae3e6976e2ed8fda Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C7=B3=C3=83=C3=8E?= <1101766085@qq.com> Date: Tue, 12 Dec 2023 16:14:23 +0800 Subject: [PATCH 1/4] =?UTF-8?q?:sparkles:=20=E4=BB=A3=E7=A0=81=E5=AE=8C?= =?UTF-8?q?=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../net/dreamlu/mica/http/ResponseSpec.java | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java b/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java index e284ebafd..d0e250c69 100644 --- a/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java +++ b/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java @@ -17,8 +17,8 @@ package net.dreamlu.mica.http; import com.fasterxml.jackson.core.type.TypeReference; +import com.fasterxml.jackson.databind.JavaType; import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.type.CollectionLikeType; import net.dreamlu.mica.core.utils.JsonUtil; import okhttp3.*; @@ -29,7 +29,6 @@ import java.nio.file.Path; import java.util.List; import java.util.Map; -import java.util.function.BiPredicate; import java.util.function.Consumer; import java.util.function.Function; import java.util.function.Predicate; @@ -216,7 +215,18 @@ default JsonNode atJsonPath(String jsonPtrExpr) { * @return JsonNode */ default T atJsonPathValue(String jsonPtrExpr, Class valueType) { - return JsonUtil.convertValue(atJsonPath(jsonPtrExpr), valueType); + return JsonUtil.treeToValue(atJsonPath(jsonPtrExpr), valueType); + } + + /** + * jackson json path 语法读取节点 + * + * @param jsonPtrExpr json path 表达式 + * @param valueType value value type + * @return JsonNode + */ + default T atJsonPathValue(String jsonPtrExpr, JavaType valueType) { + return JsonUtil.treeToValue(atJsonPath(jsonPtrExpr), valueType); } /** @@ -238,8 +248,7 @@ default T atJsonPathValue(String jsonPtrExpr, TypeReference typeReference * @return List */ default List atJsonPathList(String jsonPtrExpr, Class valueType) { - CollectionLikeType collectionLikeType = JsonUtil.getListType(valueType); - return JsonUtil.convertValue(atJsonPath(jsonPtrExpr), collectionLikeType); + return atJsonPathValue(jsonPtrExpr, JsonUtil.getListType(valueType)); } /** From b8d7eac40a84f9aee273bafda679165773cc5d29 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C7=B3=C3=83=C3=8E?= <1101766085@qq.com> Date: Fri, 15 Dec 2023 09:48:51 +0800 Subject: [PATCH 2/4] =?UTF-8?q?:sparkles:=20=E4=BB=A3=E7=A0=81=E4=BC=98?= =?UTF-8?q?=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/net/dreamlu/mica/http/HttpConsoleLogger.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mica-http/src/main/java/net/dreamlu/mica/http/HttpConsoleLogger.java b/mica-http/src/main/java/net/dreamlu/mica/http/HttpConsoleLogger.java index 877def546..cf1804398 100644 --- a/mica-http/src/main/java/net/dreamlu/mica/http/HttpConsoleLogger.java +++ b/mica-http/src/main/java/net/dreamlu/mica/http/HttpConsoleLogger.java @@ -33,7 +33,7 @@ public enum HttpConsoleLogger implements HttpLoggingInterceptor.Logger { public void log(@Nonnull String message) { // 统一添加前缀,方便在茫茫日志中查看 - System.out.printf("HttpLogger: %s\n", message); + System.out.println("HttpLogger: " + message); } } From 577754a788f3026ca28d0e71f9696724deb1d9b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C7=B3=C3=83=C3=8E?= <1101766085@qq.com> Date: Fri, 15 Dec 2023 09:57:10 +0800 Subject: [PATCH 3/4] =?UTF-8?q?:sparkles:=20=E5=AE=8C=E5=96=84=20GeoUtil?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/net/dreamlu/mica/core/geo/GeoUtil.java | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/mica-core/src/main/java/net/dreamlu/mica/core/geo/GeoUtil.java b/mica-core/src/main/java/net/dreamlu/mica/core/geo/GeoUtil.java index 86e1ef7d3..2ee505138 100644 --- a/mica-core/src/main/java/net/dreamlu/mica/core/geo/GeoUtil.java +++ b/mica-core/src/main/java/net/dreamlu/mica/core/geo/GeoUtil.java @@ -34,6 +34,22 @@ public static double getDistance(double lng1, double lat1, double lng2, double l * EARTH_RADIUS; } + /** + * 将整数形式的经纬度转换为十进制度格式 + * + * @param coordinate 整数形式的经度或纬度 + * @return 十进制度格式的经纬度 + */ + public static double getGpsValue(int coordinate) { + int degrees = coordinate / (3600 * 100); + int remainder = coordinate % (3600 * 100); + int minutes = remainder / (60 * 100); + remainder = remainder % (60 * 100); + double seconds = remainder / 100.0; + // 将分和秒转换为度的小数部分 + return degrees + (minutes / 60.0) + (seconds / 3600.0); + } + private static double radian(double d) { return d * Math.PI / 180.0; } From 81fc56a5d9ba03e3b08e2ea50564358ca80b8e30 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C7=B3=C3=83=C3=8E?= <1101766085@qq.com> Date: Fri, 15 Dec 2023 10:41:52 +0800 Subject: [PATCH 4/4] =?UTF-8?q?:sparkles:=20=E5=AE=8C=E5=96=84=20mica-http?= =?UTF-8?q?=EF=BC=8C=E6=96=B9=E4=BE=BF=E4=B8=8B=E8=BD=BD=E7=9A=84=E6=96=87?= =?UTF-8?q?=E4=BB=B6=E5=86=8D=E4=B8=8A=E4=BC=A0=E7=9A=84=E5=9C=BA=E6=99=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../net/dreamlu/mica/http/ResponseSpec.java | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java b/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java index d0e250c69..0c8b94023 100644 --- a/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java +++ b/mica-http/src/main/java/net/dreamlu/mica/http/ResponseSpec.java @@ -294,6 +294,28 @@ default List atJsonPathList(String jsonPtrExpr, Class valueType) { */ Map asMap(Class valueType); + /** + * 转换成文件上传 part + * + * @param name 表单名 + * @return Part + */ + default MultipartBody.Part asPart(String name) { + return asPart(name, null); + } + + /** + * 转换成文件上传 part + * + * @param name 表单名 + * @param fileName 文件名 + * @return Part + */ + default MultipartBody.Part asPart(String name, @Nullable String fileName) { + RequestBody requestBody = RequestBody.create(asBytes(), contentType()); + return MultipartBody.Part.createFormData(name, fileName, requestBody); + } + /** * toFile. *