- Strict separation of data and code
- Neither code nor any class information is transferred
- No code is executed through deserialization
- Objects are generated by the framework
- Injecting malicious code won't have any consequences because executing is impossible
- Implementing the interface java.io.Serializable is not required at all
- Serialize any object
- Any object from 3rd party APIs can be serialized
- Built for any complex object graphs, circular references are troublefree
- The depth of an object graph is not limited, no stack-based recursion
- No requirements to your classes, no interfaces, superclasses or annotations required
Eclipse Serializer lets you serialize any object. There are no specific superclasses, interfaces or annotations at all. Even serializing objects from third-party APIs is trouble-free.
- Implementing Serializable is not required
- No superclasses, interfaces, annotations
- Inheritance is trouble-free
- Custom-tailored type handling
The strength of it is that you can serialize any object graph of any size and complexity. The more complex your object graph is, the faster it will get in comparison.
- Any circular reference
- The depth of an object graph is not limited
- No stack-based recursion
Eclipse Serializer uses a highly optimized byte format. This enables circular references, unlimited size, complexity, and depth of your object graphs, and minimizes overhead.
The byte format can be converted into CSV and other encoding formats.
Classes evolve over time. Therefore, Eclipse Serializer provides a legacy type mapping that lets you manage different versions of your classes.
- New, changed and removed fields
- Type conversion
- Renamed and moved classes
<dependency>
<groupId>org.eclipse.serializer</groupId>
<artifactId>serializer</artifactId>
<version>2.0.0</version>
</dependency>
// create a company object
Company company = new Company();
company.setName("Acme Inc.");
// create a serializer which handles byte arrays
Serializer<byte[]> serializer = Serializer.Bytes();
// serialize a company
byte[] data = serializer.serialize(company);
// deserialize the data back to a company
company = serializer.deserialize(data);
if(company.getName().equals("Acme Inc.")) {
System.out.println("It works!");
}
Eclipse Serializer is used in EclipseStore.
If you want to contribute to this project, please read our guidelines.