【Web】关于Java反序列化那些实现机制的朴素通识

2024-03-11 09:52

本文主要是介绍【Web】关于Java反序列化那些实现机制的朴素通识,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

原生⚔ 自定义

基于 Java 原生序列化机制:

基于自定义序列化机制:

基于Bean⚔基于Field

基于 Bean 的反序列化:

基于 Field 的反序列化:

常见序列化协议归类


原生⚔ 自定义

基于 Java 原生序列化机制:

  • 特点
    1. 使用 Java 原生序列化机制,对象需要实现 java.io.Serializable 接口。
    2. 序列化采用 ObjectOutputStream,反序列化采用 ObjectInputStream
    3. 简单易用,无需额外的序列化和反序列化代码。
    4. 默认支持复杂对象图的序列化和反序列化,但对版本兼容性有一定限制。

基于自定义序列化机制:

  • 特点
    1. 使用非 Java 原生的序列化格式,如 JSON、XML 等。
    2. 需要使用第三方库或框架来实现自定义序列化和反序列化逻辑,如 Jackson、Gson 等。
    3. 序列化格式通常更紧凑、可读性好,支持跨语言、跨平台的数据交互。
    4. 可以更灵活地处理复杂对象结构、版本变更等问题,提供更好的兼容性和扩展性。

 

基于Bean⚔基于Field

基于 Bean 的反序列化:

如:SnakeYAML、jYAML、YamlBeans、Apache Flex BlazeDS、Red5 IO AMF、Jackson、Castor、Java XMLDecoder

  1. 原理

    • 基于 Bean 的反序列化是通过对象的 getter 和 setter 方法来读取和设置对象的属性值。在反序列化过程中,会根据属性名调用相应的 setter 方法为对象的属性赋值。
  2. 优点

    • 封装性好:使用 getter 和 setter 方法可以隐藏对象的内部实现细节,提供统一的访问接口。
    • 安全性高:可以通过控制 setter 方法来对属性值进行校验和处理,增强安全性。
  3. 缺点

    • 反序列化过程受限:需要保证类中存在对应的 setter 方法才能正确反序列化对象。
    • 可能影响性能:频繁调用 getter 和 setter 方法可能影响性能,特别是在大量对象的反序列化过程中。

基于 Field 的反序列化:

如:Java Serialization、Kryo、Hessian、json-io、XStream

 

  1. 原理

    • 基于 Field 的反序列化直接操作对象的字段(Field),不通过 getter 和 setter 方法。在反序列化过程中,会直接操作对象的字段来设置属性的值。
  2. 优点

    • 灵活性高:可以直接访问对象的字段,无需依赖 getter 和 setter 方法。
    • 性能较好:直接操作字段可能比通过方法调用更高效。
  3. 缺点

    • 破坏封装性:直接操作字段可能破坏对象的封装性,暴露对象的内部实现细节。
    • 安全风险:绕过 setter 方法可能导致属性值未经校验,存在安全风险。

常见序列化协议归类

序列化协议

特点

jdk
(jdk 自带)

1. 序列化:除了 static、transient类型
2. 特点:强类型,安全性高,序列化结果携带类型信息
3. 反序列化:基于 Field 机制
4. 应用场景:深拷贝

fastjson
(第三方实现)

1. 可读性好,空间占用小
2. 特点:弱类型,序列化结果不携带类型信息,可读性强。有一些安全性问题
3. 反序列化:基于 Field 机制,兼容 Bean 机制
4. 应用场景:消息、透传对象

hessian
(第三方实现)

1. 序列化:除了 static、transient 类型
2. 特点:强类型,体积小,可跨语言,序列化结果携带类型信息
3. 反序列化:基于 Field 机制,兼容 Bean 机制
4. 应用场景:RPC

这篇关于【Web】关于Java反序列化那些实现机制的朴素通识的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/797471

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏