当前位置: 首页 > news >正文

展馆门户网站建设深圳网站外包公司

展馆门户网站建设,深圳网站外包公司,网站建设 中关村,网站建设首页包括什么1.什么是序列化? 在项目的开发中,为了让前端更好的分析后端返回的结果,我们一般会将返回的信息进行序列化,序列化就是将返回对象的状态信息转换为一种标准化的格式,方便在网络中传输也方便打印日志时号观察&#xff0…

1.什么是序列化?

在项目的开发中,为了让前端更好的分析后端返回的结果,我们一般会将返回的信息进行序列化,序列化就是将返回对象的状态信息转换为一种标准化的格式,方便在网络中传输也方便打印日志时号观察,反序列化就是将序列化后的对象还原成原来的对象信息。 

2.传统方式实现序列化 

1.1 对Object类进行序列化和反序列化

我们是通过ObjectMapper中提供的writeValueAsString()方法实现序列化,通过readValue方法实现反序列化。

代码示例:

@SpringBootTest
public class JacksonTest {@Testvoid JacksonTest() throws IOException {ObjectMapper objectMapper=new ObjectMapper();CommonResult<String> commonResult=CommonResult.error(500,"系统错误");//序列化String str=objectMapper.writeValueAsString(commonResult);System.out.println("序列化后:"+str);//反序列化CommonResult commonResult1 = objectMapper.readValue(str.getBytes(StandardCharsets.UTF_8), CommonResult.class);System.out.println("反序列化后:"+commonResult1);
}

运行代码

 

1.2 对List类进行序列化和反序列化

对List的序列化和对Object类的序列化方法一样,不过List类的反序列化需要多一步操作。

  

通过readValue方法的原码发现,第二个参数是Class类型。

由于Java的泛型在编译时会进行类型擦除,这意味着在运行时,泛型的具体类型信息只保留原始类型,例如List<CommonResult>中的CommonResult是通过泛型的形式传递的,编译时CommonResult里的具体信息就会被擦除,运行时就会被视为List,此时List类型中的CommonResult参数的信息可能会丢失或者欠缺了,如果直接将序列化后的List类型直接反序列化为原来的数据,可能会导致CommonResult类型信息丢失,从而引发问题。

所以,此时,我们要构建一个参数化类型,即带有泛型参数的具体类型,以上面为例,我们就需要构建一个List<CommonResult>的参数类型,这个通过下图方法实现

代码实现:

 

@SpringBootTest
public class JacksonTest {@Testvoid JacksonTest() throws IOException {ObjectMapper objectMapper=new ObjectMapper();  String str;//List的序列化List<CommonResult<String>> resultList= Arrays.asList(CommonResult.success("成功1"),CommonResult.success("成功2"));str=objectMapper.writeValueAsString(resultList);System.out.println("序列化后:"+str);//List的反序列化//构造一个带有泛型参数的具体类型JavaType javaType=objectMapper.getTypeFactory().constructParametricType(List.class,CommonResult.class);resultList=objectMapper.readValue(str,javaType);for(CommonResult result:resultList){System.out.println("反序列化后:"+result);}}

在这种实现方式中,我们需要主动处理writeValueAsString和readValue方法抛出的异常,这意味着我们每次调用这两个方法都要处理这两个方法抛出的异常,这是在有点麻烦切有点不美观,如果我们使用的是catch来捕捉异常,这样代码就会变得很难看。

3.模仿springboot原码中实现序列化和反序列化 

 

通过观察原码发现spring中的parseMap和ParseList都是通过tryParse方法来实现反序列化的,tryParse的原码如下图加分析

 

 

所以此时, 我们可以将原码中的tryParse方法复制一份我们模仿实现的代码中,并且用单例模式让ObjectMapper只能被构建一次。

package com.example.lotterysystem.common.utils;import com.fasterxml.jackson.core.JacksonException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.boot.json.JsonParseException;
import org.springframework.util.ReflectionUtils;import java.util.List;
import java.util.concurrent.Callable;public class JacksonUtil {//单例构造要私有Jackson的私有方法private JacksonUtil(){}//单例操作private static final ObjectMapper OBJECT_MAPPER;static {OBJECT_MAPPER=new ObjectMapper();}private static ObjectMapper getObjectMapper(){return OBJECT_MAPPER;}//有队tryParse方法进一步封装,将tryParse捕获的类型写死private static  <T> T tryParse(Callable<T> parser){return tryParse(parser, JacksonException.class);}private static  <T> T tryParse(Callable<T> parser, Class<? extends Exception> check) {try {return parser.call();} catch (Exception var4) {if (check.isAssignableFrom(var4.getClass())) {throw new JsonParseException(var4);}throw new IllegalStateException(var4);}}/*** 序列化方法* @param object* @return*/public static String writeValueAsString(Object object){return JacksonUtil.tryParse(()->{return JacksonUtil.getObjectMapper().writeValueAsString(object);});}/*** 反序列化Object类型数据* @param content* @param valueType* @param <T>* @return*/public static<T> T readValue(String content,Class<T> valueType){return JacksonUtil.tryParse(()->{return JacksonUtil.getObjectMapper().readValue(content,valueType);});}/*** 反序列化List类型* @param content* @param paramClasses* @param <T>* @return*/public static <T> T readListValue(String content,Class<?> paramClasses){JavaType javaType=JacksonUtil.getObjectMapper().getTypeFactory().constructParametricType(List.class,paramClasses);return JacksonUtil.tryParse(()->{return JacksonUtil.getObjectMapper().readValue(content,javaType);});}
}

测试代码

@Testvoid JacksonUtilTest(){CommonResult<String> result=CommonResult.success("成功");String str;//序列化str= JacksonUtil.writeValueAsString(result);System.out.println("序列化后:"+str);//反序列化result=JacksonUtil.readValue(str,CommonResult.class);System.out.println("反序列化后:"+result);System.out.println("下面是List序列化");//List的序列化List<CommonResult<String>> resultList= Arrays.asList(CommonResult.success("成功1"),CommonResult.success("成功2"));str=JacksonUtil.writeValueAsString(resultList);System.out.println("序列化后:"+str);//list的反序列化List<CommonResult<String>> results=JacksonUtil.readListValue(str,CommonResult.class);for(CommonResult son:results){System.out.println("反序列化后:"+son);}}

 

 

http://www.dtcms.com/a/550016.html

相关文章:

  • MATLAB高效算法实战
  • 网站导航图怎么做的详细步骤郑州发布直播
  • 做网站灰色网站怎么判刑北邻京网站茵建设
  • MySQL 读写分离:用 ProxySQL 实现 “读走从库,写走主库”(附延迟问题解决方案)
  • C Primer Plus Notes 10
  • wap网站制作动态如何做色流量网站
  • 【BTC】分叉
  • 高端建站咨询wordpress 音乐播放器 歌词
  • 网站开发北京外贸公司大全
  • 最便宜网站空间做h5好点的网站
  • 网站的建设与板块如何保存wordpress主题设置
  • 基于hadoop的电商用户行为分析系统(源码+论文+部署+安装)
  • 通达oa 做网站可以做动图的视频网站
  • 做黄金比较专业的网站网站自助制作
  • 长沙建站工作室乐陵森林覆盖率
  • 移动电子商务网站建设深圳公司建立网站
  • 1.0 机器学习实际上是什么
  • 352-Spring AI Alibaba OpenAI DashScope 多模态示例
  • 网站的备案用wordpress建站域名和空间哪里买比较好
  • vue3 中组件的生命周期详解
  • 单片机实现队列功能
  • 魔多 AI 支持 Seedance 系列在线生成:赠送免费生成额度
  • 怎样建立一个主题网站群晖做网站服务器 套件
  • 淘客app网站是怎么做的深圳做网站佰达科技三十
  • 【JavaScript】构造函数与 new 运算符
  • OpenEuler 22.03 安装 snmptt 1.5
  • 摇杆控制View
  • 常州网站建设段新浩网站推广公司有哪些
  • TCP三次握手和四次断开
  • 黑马JAVA+AI 加强08 File-IO流