首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java 的序列化 与 反序列化

在操作 Redis 遇到了 RedisTemplate 存储对象放进去 Redis中,取出来的时候,无法恢复成Java对象了。真他妈操蛋。耽误我半天时间,于是,准备狠狠的搞一手 序列化相关的问题。...序列化的定义 把对象转换为字节序列的过程称为: 对象的序列化 把字节序列恢复未对象的过程被称为:对象反序列化 为什么要序列化? 我们进行网络传输的时候,是以 二进制数据为单位的。...比如我们存储Redis数据,假设我们有个 对象叫user,但是 Redis 可识别不了我们Java 虚拟机内存中的 user对象。Redis 只认识 String。...我们将来从Redis读取的字节时候,我们就需要转成Java 对象,我们才能用Java代码进行处理,所以,我们必须按照一个规矩 将对象 进行 所谓的 “加密” 然后 存储后。...我们读取的时候 再 “解密“。 “加密” 就叫 序列化 ,”解密” 就叫 反序列化。

55520
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java的序列化与反序列化

    前言 Java的序列化与反序列化是Java中比较重要的一个知识,本文将总结一下,怎么使用序列化功能以及经常遇到的一些问题的解答....什么是Java的序列化 JDK提供给我们的,可以将某一个对象转化为二进制字节流保存,并从字节流恢复对象的一种技术. 我们可以再网络传输对象,或者持久化对象时使用这项技术....怎么进行序列化与反序列化 Java中通过继承Serializable接口来获得序列化与反序列化的能力,使用ObjectInputStream和ObjectOutputStream来进行具体的对象序列化读写...序列化和反序列化的匹配是怎么匹配的?总不能随便来的吧,A类序列化后的二进制文件,B类能从哪里读出一个对象来嘛? 不能,类的路径以及功能代码必须完全相同,而序列化ID也是用来补充这一判断的....总结 1.java的序列化需要实现Serializable接口,之后使用ObjectOutputStream及ObjectInputStream进行读写. 2.必须实现Serializable是因为JDK

    61620

    Java对象的序列化和反序列化

    Java 的序列化和反序列化提供了一种方便的方式,使得可以将对象在不同的应用程序之间进行交互。一、什么是 Java 序列化和反序列化?...Serializable 是一种标记接口,它没有方法定义,但它具有一个特别的作用,就是用于在描述 java 类可序列化时做类型判断的信息。...当一个类实现 Serializable 接口时,表明这个类是可序列化的。Serializable 接口只是一个标识接口,我们并不需要重载任何方法。...该类的所有字段都必须是可序列化的。如果一个字段不需要序列化,则需要使用transient 关键字open in new window进行修饰。...ProtobufProtobuf 是 Google 开源的一种轻量级、高效、可扩展的序列化框架,支持多种编程语言。

    1.4K00

    java 的序列化和反序列化的问题

    引言 将 Java 对象序列化为二进制文件的 Java 序列化技术是 Java 系列技术中一个较为重要的技术点,在大部分情况下,开发人员只需要了解被序列化的类需要实现 Serializable 接口...然而在有些情况下,光知道这些还远远不够,文章列举了笔者遇到的一些真实情境,它们与 Java 序列化相关,通过分析情境出现的原因,使读者轻松牢记 Java 序列化中的一些高级认识。...在父类没有实现 Serializable 接口时,虚拟机是不会序列化父对象的,而一个 Java 对象的构造必须先有父对象,才有子对象,反序列化也不例外。...特性使用案例 RMI 技术是完全基于 Java 序列化技术的,服务器端接口调用所需要的参数对象来至于客户端,它们通过网络相互传输。这就涉及 RMI 的安全传输的问题。...解答:Java 序列化机制为了节省磁盘空间,具有特定的存储规则,当写入文件的为同一对象时,并不会再将对象的内容进行存储,而只是再次存储一份引用,上面增加的 5 字节的存储空间就是新增引用和一些控制信息的空间

    906100

    Java中的序列化

    序列化 1.1 序列化概述 Java中提供了一种序列化操作的方式,用一个字节序列化来表示一个对象,该字节序列化中保存了【对象的属性】,【对象的类型】和【对象的数据】。...把字节序列化保存到文件中,就可以做到持久化保存数据内容。 从文件中读取字节序列化数据,可以直接得到对应的对象。...java.io.Serializable。不遵从无法进行序列化操作 序列化之后从文件中读取序列化内容,转换成对应的对象, ClassNotFoundException 对应类没有找到。...对应的类型没有导包,不存在… InvalidClassException 类型不一样 序列化之后的每一个类都会有一个serialVersionUID,该编号在使用过程中,序列化 和反序列化必须一致...transient 修饰的成员变量不能被序列化

    56330

    java序列化和序列化ID的作用

    谈到java序列化其实大家都能说出一二, java对象序列化的意思就是将对象的状态转化成字节流,以后可以通过这些值再生成相同状态的对象。...同时添加序列化,会进行一系列的比较操作,可参考序列化机制,也会占资源,所以不需要流传输的就大可不必序列化。...序列化的漏洞 如果Java应用对用户输入,即不可信数据做了反序列化处理,那么攻击者可以通过构造恶意输入,让反序列化产生非预期的对象,非预期的对象在产生过程中就有可能带来任意代码执行。...所以这个问题的根源在于类ObjectInputStream在反序列化时,没有对生成的对象的类型做限制;假若反序列化可以设置Java类型的白名单,那么问题的影响就小了很多。...序列化ID的作用 序列化ID起着关键的作用,java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。

    1.4K20

    可串行化 数据库恢复 观测可序列化

    可串行化 冲突可串行化是可串行化的充分条件 CLR Compensation Log Record 数据库恢复 分析阶段 graph TD A(把事务加入事务表)-->C(把已结束的事务剔除出事务表)...C --> D(把影响到的页加入脏表, recLSN选最早影响它的日志的LSN) 重做阶段 把检查点后,崩溃前的没提交的事务的更新和CLR再过一遍,目的是使数据库恢复到崩溃时的状态。...反做阶段 graph TD B(确定没完成的事务) --> |构建undo| A A{查看undo集里的项}-->|有update| C(对应加入CLR) A -->|有CLR| D(一直添加CLR直到它们都被...undo) 根据没完全完成的事务,如果undo集有update就对应加入CLR,如果有CLR就一直添加CLR直到它们都undo。...观测可序列化 很好的参考文章

    78440

    Java 序列化

    引言 我们经常在 java 中使用序列化,序列化成一个二进制文件,需要的时候再反序列化,但是一直只知道只要实现 Serializable 接口就可以了,一直不知道具体的原理,我们今天就来一探究竟。...注意方法的改变不影响,因为序列化只序列化属性,跟方法无关 如果你不在类中声明SerialVersionUID的话,Java会在运行时替你生成一个,不过这个生成的过程会受到类元数据包括字段数,字段类型,...字段的访问限制符,类实现的接口等因素的影响. ---- 静态变量的问题 看代码 import java.io.*; public class Demo implements Serializable...==序列化保存的是对象的状态,静态变量属于类的状态,因此 序列化并不保存静态变量。...,然后从文件中反序列化出两个对象,比较这两个对象是否为同一对象 Java 序列化机制为了节省磁盘空间,具有特定的存储规则,当写入文件的为同一对象时,并不会再将对象的内容进行存储,而只是再次存储一份引用,

    72720

    java序列化

    # 背景 java对象是在jvm中,如果jvm销毁,那么对象都不存在了。...如果想继续使用java对象的话,需要用到序列化,将java中的对象转化为字节序列,用于存储和运输; 那么可以将DB理解为一种序列化,将java对象序列化后存储在DB中,将java对象保存在文本中也是一种序列化...# 细节 需要被序列化的类,需要实现Serializable接口 虽然Serializable接口是空的,没有任何方法,但也要实现,起到标识的作用 同一字节流中的引用是得到保存的 User user...(同一输出流),会发现两个对象的o1.user == o2.user 但将两个对象分别保存在不同文件中,file1和file2的话,引用是不一样的 o1.user !...= o2.user 反序列化没有调用构造函数 public class User implements Serializable { private String name; private

    56210

    Java序列化

    什么是序列化,如何实现序列化 概述 Java序列化是指将Java对象转换为二进制字节流,以便于持久化和传输的过程。...反之,则称为反序列化 默认的序列化实现由JVM负责,可序列化的对象需要实现Serializable接口 Serializable接口不包含任何方法,只用于标记该对象可序列化;若未实现该接口,则序列化时会报...Externalizable Externalizable 序列化的优先级比Serializable的优先级高 使用 Externalizable 进行序列化时,必须要有默认的构造方法,而Serializable...这是因为使用 Externalizable 进行反序列化时,需要有默认的构造方法,通过反射先创建出该类的实例,然后再把解析后的属性值,通过反射赋值 其他注意事项 静态变量不会被序列化 transient.../java-externalizable

    11110

    Java 序列化

    RMI(远程方法调用) 序列化和反序列化 Java 通过对象输入输出流来实现序列化和反序列化: 序列化:java.io.ObjectOutputStream 类的 writeObject() 方法可以实现序列化...serialVersionUID 是 Java 为每个序列化类产生的版本标识。它可以用来保证在反序列时,发送方发送的和接受方接收的是可兼容的对象。...如果可序列化类没有显式声明 serialVersionUID,则序列化运行时将基于该类的各个方面计算该类的默认 serialVersionUID 值。...综上所述,我们大概可以清楚:serialVersionUID 用于控制序列化版本是否兼容。若我们认为修改的可序列化类是向后兼容的,则不修改 serialVersionUID。...readResolve() 方法 当我们使用 Singleton 模式时,应该是期望某个类的实例应该是唯一的,但如果该类是可序列化的,那么情况可能会略有不同。

    52900

    Java序列化进阶:Java内置序列化的三种方式

    Java序列化就是把Java对象按照一定的格式存到文件或者磁盘当中,那么Java内置的序列化有几种方式呢?每种方式的相同点和不同点是什么呢?...序列化的进阶:即三种方式,任何一种方式都可以进行序列化和反序列化 第一种 使用默认的序列化机制,即实现Serializable接口即可,不需要实现任何方法。...该接口没有任何方法,只是一个标记而已,告诉Java虚拟机该类可以被序列化了。然后利用ObjectOutputStream进行序列化和用ObjectInputStream进行反序列化。...注意: 该方式下序列化机制会自动保存该对象的成员变量,static成员变量和transient关键字修饰的成员变量不会被序列化保存。如: ? 要序列化的对象 看看序列化和反序列化效果: ?...这种方式一定要显式的序列化成员变量,使得整个序列化过程是可控制的,可以自己选择将哪些部分序列化。

    2.3K20

    Java 序列化

    Java序列化是指把Java对象转换为字节序列的过程 Java反序列化是指把字节序列恢复为Java对象的过程 我们知道,当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等...使用场景:所有可在网络上传输的对象都必须是可序列化的,比如RMI(remote method invoke,即远程方法调用),传入的参数或返回的对象都是可序列化的,否则会出错;所有需要保存到磁盘的java...对象都必须是可序列化的。...如果此对象已经序列化过,则直接输出编号即可。 普通序列化 Serializable接口是一个标记接口,不用实现任何方法。一旦实现了此接口,该类的对象就是可序列化的。...成员是引用的序列化 如果一个可序列化的类的成员不是基本类型,也不是String类型,那这个引用类型也必须是可序列化的;否则,会导致此类不能序列化。

    1.2K00

    什么是 java 序列化,如何实现 java 序列化?

    序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进 行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之 间。...序列化是为了解决在对对象流进行读写操作时所引发的问题; 序列化的实现:将需要被序列化的类实现 Serializable 接口,该接口没有需实 现的方法,implements Serializable 只是为了标注该对象是可被序列化的...,然 后使用一个输出流(如 FileOutputStream)来构造一个 ObjectOutputStream(对 象流)对象,接着,使用 ObjectOutputStream 对象的 writeObject...(Object obj) 方法就可以将参数为 obj 的对象写出(即保存其状态),要恢复的话则用输入流。

    63010

    Java基础18:Java序列化与反序列化

    本文介绍了Java序列化的基本概念,序列化和反序列化的使用方法,以及实现原理等,比较全面地总结序列化相关知识点,并且使用具体例子来加以佐证。...Java对象的序列化与反序列化 在Java中,我们可以通过多种方式来创建对象,并且只要对象没有被回收我们都可以复用该对象。但是,我们创建出来的这些Java对象都是存在于JVM的堆内存中的。...Java的对象序列化可以帮助我们实现该功能。...相关接口及类 Java为了方便开发人员将Java对象进行序列化及反序列化提供了一套方便的API来支持。...未实现此接口的类将无法使其任何状态序列化或反序列化。可序列化类的所有子类型本身都是可序列化的。序列化接口没有方法或字段,仅用于标识可序列化的语义。

    1K00

    【Java】序列化与反序列化

    对象的序列化机制是什么? 对象序列化机制允许把内存中的Java对象转化成语平台无关的二进制流,从而允许把这种二进制流持久的保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点。...当其他程序获取了这种二进制流,就可以恢复成原来的Java对象。 2....Java自定义类序列化要求: 自定义类需要实现接口:Serializable(标识接口:无任何属性或抽象方法),否则会报NotSerializableException 异常 要求自定义类声明一个全局常量...要求自定义类的各个属性也必须是可以序列化的: 对于基本数据类型:默认就可以序列化,因为底层已经实现类了Serializable接口 若某个属性是引用数据类型:那么这个属性所在类也要求实现Serializable...若某个属性不想被序列化,则该属性必须注明是瞬态的,使用transient关键字修饰。 静态(static)变量的值不会序列化。因为静态变量的值不属于某个对象 是属于类的。

    64110

    【Java】序列化和反序列化

    java序列化指的是将java对象转化为字节序列的过程。 java反序列化指字节序列恢复到java对象。 一、基础知识 计算机内存最小单位为一个二进制位,即 0或1。...序列化是把对象转换成有序字节流,以便在网络上传输或者保存在本地文件中。序列化后的字节流保存了Java对象的状态以及相关的描述信息。序列化机制的核心作用就是对象状态的保存与重建。...JDK类库中序列化和反序列化API java.io.ObjectOutputStream: 表示对象输出流; 它的writeObject(Object obj)方法可以对参数指定的obj对象进行序列化...实现Java对象序列化与反序列化的方法 若User类仅仅实现了Serializable接口,则可以按照以下方式进行序列化和反序列化: ObjectOutputStream采用默认的序列化方式,对User...重要点在意思是按照不同类型的方法去写入序列化数据,可以看上面实现Java对象序列化与反序列化的方法。 我们实例中实现了Serializable,所以执行writeOrdinaryObject方法。

    13310

    java序列化和反序列化

    Java序列化和反序列化是将Java对象转换为字节流和将字节流转换为Java对象的过程。...在本文中,我们将探讨Java序列化和反序列化的基本原理以及如何使用Java进行序列化和反序列化。Java序列化Java对象序列化是将Java对象转换为字节流的过程,使其可以在网络上传输或存储在磁盘上。...Java对象的所有成员变量都必须是可序列化的。如果对象的某些成员变量不可序列化,则可以将它们标记为transient,以防止它们被序列化。...我们将读取的对象转换为Student类型,并输出其名称和年龄。Java序列化和反序列化的注意事项在使用Java序列化和反序列化时,需要注意以下事项:序列化和反序列化的Java对象必须是同一版本。...如果序列化的对象和反序列化的对象不是同一版本,可能会导致ClassCastException异常。如果Java对象包含对其他对象的引用,那么这些对象也必须是可序列化的。

    93630

    【JAVA反序列化】序列化与反序列化&Java反射&URLDNS链

    原生序列化与反序列化 序列化:JAVA对象转换成字节序列的过程;将数据分解为字节流,以便存储在文件中或在网络上传输;用一个字节序列表示一个对象,该字节包含对象的数据、对象的类型、对象的存储属性。...序列化对象会通过ObjectOutputStream的writeObject方法将一个对象写入到文件中 反序列化:字节序列恢复成JAVA对象的过程;打开字节流并重构对象,反序列化是使用了readObject...当两个进程进行远程通讯时需要Java序列化与反序列化(可以相互发送各种数据,包括文本、图片、音频、视频等) 发送方需要把这个Java对象转换成字节序列(二进制序列的形式),然后在网络上传送,另一方面,接收方需要从字节序列中恢复出...Java对象 应用场景(涉及到将对象转换成二进制,序列化保证了能够成功读取到保存的对象) 想把内存中的对象保存到一个文件中或者数据库中时候 想用套接字在网络上传送对象的时候 想通过RMI传送对象的时候...(可序列化的类)) Person类中含有执行系统命令的方法 private void readObject(ObjectInputStream ois) throws IOException

    18010
    领券