当今社会下,前后端分离,不同系统的信息交互,消息队列的数据传递,微服务的不同服务之间的数据处理,越来越多地方用到了序列化。序列化作为不同系统不同服务之间的数据桥梁。那么方便快捷的序列化工具还是必要的。

相对应配置在springboot本身的消息队列,使用gson进行代码中转化,具有不同情境下使用不同配置的优势。

该需求的来源还是来资源我这边和C#开发的系统进行数据对接时,导致的一些小问题。

我大致描述下对面系统的开发形式。现阶段,大家都是使用实体类的形式将整个实体类进行统一序列化。对方系统采用的是实体类嵌套实体类,关键该实体类还是写在同一个class下面的,也就存在一个问题,相同类型的实体类,写在不同class下面后导致部分的字段会存在一定的差异,虽然对面尽量避免这个问题了,但是偶尔还是出来了。更为关键的是,他们的首字母存在一会大写,一会小写的情况。给出的文档让我。

那么我这边采用字符串接收的形式,接收到之后,我再通过通过Gson的形式进行数据实例化。

那么在使用Gson的时候需要GsonBuilder来创建通过其进行gson实例化的简单配置。

1   private final Gson gson = new GsonBuilder()//建造者模式设置不同的配置
2 .serializeNulls()//序列化为null对象
3 .disableHtmlEscaping()//防止对网址乱码 忽略对特殊字符的转换
4 .registerTypeAdapter(String.class, new StringConverter())//对为null的字段进行转换
5 .registerTypeAdapter(Date.class, new DeanDateConverter())//对为null的字段进行转换
6 .create();

Gson创建

小伙伴们可以看到,我的类型适配是存在两个的,一种是String类型,一种是Date类型。String类型大家都好理解,为什么要使用Date类型呢,因为对面大量使用了java中的DateTime时间格式,中间还夹杂着正常的时间格式。DateTime默认事件格式是中间存在T的。那么就给自动转化时间类型提高了难度。那么干脆点,我直接将定义为Date类型的对应数据拉出来,通过字符串解析进行控制,不同的类型走不同的转换。

这里逻辑比较简单,我就直接上源码了

import com.google.gson.*;
import org.apache.http.util.TextUtils; import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.*; public class GsonBinder { //定义并配置gson
private final Gson gson = new GsonBuilder()//建造者模式设置不同的配置
.serializeNulls()//序列化为null对象
// .setDateFormat("yyyy-MM-dd HH:mm:ss") //设置日期的格式
.disableHtmlEscaping()//防止对网址乱码 忽略对特殊字符的转换
.registerTypeAdapter(String.class, new StringConverter())//对为null的字段进行转换
.registerTypeAdapter(Date.class, new DeanDateConverter())//对为null的字段进行转换
.create(); /**
* 对解析数据的形式进行转换
*
* @param obj 解析的对象
* @return 转化结果为json字符串
*/
public String toJsonStr(Object obj) {
if (obj == null) {
return "";
}
try {
return gson.toJson(obj);
} catch (Exception e) {
return "";
}
} /**
* 解析为一个具体的对象
*
* @param json 要解析的字符串
* @param obj 要解析的对象
* @param <T> 将json字符串解析成obj类型的对象
* @return
*/
public <T> T toObj(String json, Class<T> obj) {
//如果为null直接返回为null
if (obj == null || TextUtils.isEmpty(json)) {
return null;
}
try {
return gson.fromJson(json, obj);
} catch (Exception e) {
e.printStackTrace();
return null;
} } /**
* @return 不区分类型 传什么解析什么
*/
public <T> T toObj(String jsonStr, Type type) {
return gson.fromJson(jsonStr, type);
} /**
* 将Json数组解析成相应的映射对象列表
* 解决类型擦除的问题
*/
public <T> List<T> toList(String jsonStr, Class<T> clz) {
List<T> list = gson.fromJson(jsonStr, new type(clz));
if (list == null) list = new ArrayList<>();
return list;
} public <T> Map<String, T> toMap(String jsonStr, Class<T> clz) {
Map<String, T> map = gson.fromJson(jsonStr, new type(clz));
if (map == null) map = new HashMap<>();
return map;
} private class type implements ParameterizedType {
private Type type; private type(Type type) {
this.type = type;
} @Override
public Type[] getActualTypeArguments() {
return new Type[]{type};
} @Override
public Type getRawType() {
return ArrayList.class;
} @Override
public Type getOwnerType() {
return null;
}
} }

Gson代码

 1 import com.google.gson.*;
2 import com.seekingtrue.dean.unit.DeanUtils;
3 import org.joda.time.DateTime;
4
5 import java.lang.reflect.Type;
6 import java.text.ParseException;
7 import java.util.Date;
8
9 public class DeanDateConverter implements JsonSerializer<Date>, JsonDeserializer<Date> {
10
11 @Override
12 public Date deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
13 System.out.println("时间类型");
14 String deanTemp = json.toString().replace("\"","");
15 Date needDate=null;
16 if (deanTemp.equals("null")){
17 return needDate;
18 }
19 if (deanTemp.indexOf("T")!=-1){
20 DateTime dateTime = new DateTime(deanTemp);
21 needDate = dateTime.toDate();
22 }else {
23 DeanUtils deanUtils = new DeanUtils();
24 String fommate = "yyyy-MM-dd HH:mm:ss";
25 fommate.substring(0,deanTemp.length());
26 try {
27 deanUtils.changeStringToDate(deanTemp,fommate);
28 } catch (ParseException e) {
29 return null;
30 }
31 }
32 return needDate;
33 }
34
35 @Override
36 public JsonElement serialize(Date src, Type typeOfSrc, JsonSerializationContext context) {
37 if (src==null){
38 return null;
39 }
40 DateTime dateTime = new DateTime(src);
41 return new JsonPrimitive(dateTime.toString());
42 }
43 }

时间类型转换

那么同一个字段不同名称如何处理呢,那么还是使用gson本身的配置功能。  @SerializedName(value = "BingRenID",alternate = {"bingRenID"}),别名多了就多配置点。问题就不大了。

Gson的使用与理解的更多相关文章

  1. 完全理解Gson(1):简单入门

    GSON是Google开发的Java API,用于转换Java对象和Json对象.本文讨论并提供了使用API的简单代码示例.更多关于GSON的API可以访问:http://sites.google.c ...

  2. 完全理解Gson(2):Gson序列化

    通过调用 Gson API 可以把 Java 对象转换为 JSON 格式的字符串(项目主页).在这篇文章中,我们将会讲到如何通过 Gson 默认实现和自定义实现方式,将 Java  对象转换为 JSO ...

  3. 完全理解Gson(3):Gson反序列化

    完全理解Gson(2):Gson序列化 完全理解Gson(1):简单入门 本文延续前一篇文章,继续介绍简单基本的Gson用法.这篇文章我们将介绍如何将复杂的JSON对象解析为Java对象,其中Java ...

  4. 从高处理解android与服务器交互(看懂了做开发就会非常的容易)

    今天帮一个朋友改一个bug 他可以算是初学者吧 .我给他看了看代码,从代码和跟他聊天能明显的发现他对客户端与服务器交互 基本 不是很了解.所以我花了更多时间去给他讲客户端与服务器的关系.我觉得从这个高 ...

  5. json工具包比较 fastjson jackson gson

    对json进行json-object进行相互转化时,笔者接触到三种工具jar,现对其进行比较. fastjson:速度最快,阿里巴巴开源. jackson:springMvc 默认使用. gson:谷 ...

  6. Android网络之数据解析----使用Google Gson解析Json数据

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  7. Gson ------ 实例演习

    [本文范围]: 本文并非JSON知识讲解资料,亦非GSON知识讲解资料,而是通过实例让开发人员了解通过Gson如何使Java对象和Json对象进行相互转换. [JSON参考资料]: Json快速入门: ...

  8. JSON数据解析及gson.jar包

    从服务器端接收数据的时候,那些数据必须以浏览器能够理解的格式来发送. 服务器端的编程语言只能以如下 3 种格式返回数据: HTML XML JSON JSON一种简单的数据格式,比xml更轻巧. JS ...

  9. 关于Gson定制的分析

    首先,为什么需要定制呢?很多同学可能觉得默认的不也挺好的嘛?最开始,我也是觉得的,而且我们一开始也是用默认的解析方式的,因为我们与外部约定的数据格式一直都比较稳定.但当外部数据不稳定,那么Gson默认 ...

随机推荐

  1. list集合的介绍和常用方法

    List接口介绍 java.util.List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象成为List集合.在List集合中允许出现重复的元素,所 ...

  2. .NET性能优化-使用SourceGenerator-Logger记录日志

    前言 在现在许许多多的应用系统中,日志非常关键,它即是排查问题的强力工具,也是程序员居家旅行工作甩锅必备良品. 在团队中编码中,我们都要求对于那些会变更数据的接口.调用第三方的接口记录请求和响应参数, ...

  3. Spark: Cluster Computing with Working Sets

    本文是对spark作者早期论文<Spark: Cluster Computing with Working Sets>做的翻译(谷歌翻译),文章比较理论,阅读起来稍微有些吃力,但读完之后总 ...

  4. GP查询表状态常用SQL

  5. Linux系列之重定向操作

    前言 I/O重定向允许我们将命令的输入和输出重定向到文件中,以及将多个命令连接到一起成为管道.本文就来介绍有关重定向的知识. 标准输入.输出.错误 输出包括两种类型: 程序的结果.被称为标准输出或者s ...

  6. BMP位图之8位位图(三)

    起始结构 typedef struct tagBITMAPFILEHEADER { WORD bfType; //类型名,字符串"BM", DWORD bfSize; //文件大小 ...

  7. 设置Windows Server 2022、Win10、Win11自动登录的简单方法-OK

    这里介绍自己从使用 Windows Server 2003 到 Windows Server 2022 一直都在使用的自动登录系统的方法,屡试不爽.网上讨论的方法太繁琐,所以共享出来,供大家参考.该方 ...

  8. js中数组去重的方法

    在实际工作或面试中,我们经常会遇到"数组去重"问题,接下来就是使用js实现的数组去重的多种方法: 1.借助ES6提供的Set结构 var arr = [1,1,2,2,3,3,4, ...

  9. Tomcat报错:类XXXServlet不是Servlet 解决方法

    学习servlet 结果对应网页打不开,报错 HTTP状态 500 - 内部服务器错误 类型 异常报告 消息 类HelloServlet不是Servlet ... 根本原因. java.lang.Cl ...

  10. ASP.NET Core依赖注入系统学习教程:容器对构造函数选择的策略

    .NET Core的依赖注入容器之所以能够为应用程序提供服务实例,这都归功于ServiceDescriptor对象提供的服务注册信息.另外,在ServiceDescriptor对象中,还为容器准备了3 ...