Welcome!

Related Topics: Java IoT, Machine Learning , Apache

Java IoT: Blog Post

Java Serialization without Serializable Interface

As you know in case of Core Java to serialize an object it is mandatory to implement Serializable interface and serialVersionUID

The title of this article seems unpleasant as it talks about serializing java object graph without the use of Serializable interface. It is true in case of Core Java. We know that to serialize a java bean we have to implement Serializable interface ( let us not consider the Externalizable interface ).In this article I will show how it is possible to serialize a java object without implementing Serializable interface using a library from a famous organisation called Jboss. In this small post I will make you familiar with “Jboss Serialization”.

Technicalities
As you know in case of Core Java to serialize an object it is mandatory to implement Serializable interface and serialVersionUID( optional ). There are certain situations in the project development where we want to serialize the object but that particular object does not implement Serializable interface and we may not have access to the source code. In this case I am not saying that it is impossible to we will find it difficult to serialize the object graph. But the introduction of Jboss Serialization API made it very simple to serialize an object irrespective of the serialization specification.  To use “Jboss Serialization” you have to download the zip file available in jboss site. The link for download is given below in the references section. You have to note that jboss serialization api depends upon two other libraries called “log4j.jar” and “trove.jar”. You have to put the two jar files in the classpath along with “jboss-serialization.jar”. If you are using normal java project you should have three jar files in your library as mentioned below.

log4j.jar

trove.jar

jboss-serialization.jar

If you are using Maven, you have to use the following dependency as mentioned below.

<dependency>

<groupId>jboss</groupId>

<artifactId>jboss-serialization</artifactId>

<version>4.2.2.GA</version>

</dependency>

How to do

Let us consider a very small example of java Object graph ie Organisation object contains Employee object which has name and id as fields. The code is given below.

package com.ddlab.jboss.serilization;

/**

* This is a plain java class with the fields name and id.

*

* @author <a href="mailto:debadatta.mishra@gmail.com"> Debadatta Mishra (PIKU)

* @Since Jan 2013

*/

public class Employee {

private String name;

private String id;

// ~~ Getter and Setter Methods below

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

}

 

 

 

 

package com.ddlab.jboss.serilization;

/**

* This is a plain java class with the field type {@link Employee}.

*

* @author <a href="mailto:debadatta.mishra@gmail.com"> Debadatta Mishra (PIKU)

* @Since Jan 2013

*/

public class Organisation {

private Employee emp;

public Employee getEmp() {

return emp;

}

public void setEmp(Employee emp) {

this.emp = emp;

}

}

In the above case you can mark that none of the classes implement Serializable interface. Ok, that’s great. To use jboss serialization and deserialization only replace “ObjectOutputStream” to “JBossObjectOutputStream” and “ObjectInputStream” to “JbossObjectInputStream”. Let us see concrete example code below.

package com.ddlab.jboss.serilization;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.OutputStream;

import org.jboss.serial.io.JBossObjectInputStream;

import org.jboss.serial.io.JBossObjectOutputStream;

/**

* This is a testharness class used to serialize and deserialize the object.

*

* @author <a href="mailto:debadatta.mishra@gmail.com"> Debadatta Mishra (PIKU)

* @Since Jan 2013

*/

public class TestJbossSerilization {

public static void storeObject(Organisation org, String filePath) {

JBossObjectOutputStream objOut = null;

OutputStream out = null;

File file = new File(filePath);

try {

out = new FileOutputStream(file);

} catch (FileNotFoundException e) {

e.printStackTrace();

}

try {

objOut = new JBossObjectOutputStream(out);

objOut.writeObject(org);

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

if (objOut != null)

objOut.close();

if (out != null)

out.close();

} catch (IOException e) {

e.printStackTrace();

}

}

System.out

.println("Object Organisation is serialized successfully in the path "

+ file.getAbsolutePath());

}

public static void retrieveObject(String filePath) {

InputStream inStream = null;

try {

inStream = new FileInputStream(filePath);

} catch (FileNotFoundException e) {

e.printStackTrace();

}

JBossObjectInputStream objIn = null;

try {

objIn = new JBossObjectInputStream(inStream);

} catch (IOException e) {

e.printStackTrace();

}

Organisation org;

try {

org = (Organisation) objIn.readObject();

System.out.println("Employee Name : " + org.getEmp().getName());

System.out.println("Employee Id : " + org.getEmp().getId());

} catch (IOException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

} finally {

try {

if (objIn != null)

objIn.close();

if (inStream != null)

inStream.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

public static void main(String[] args) throws Exception {

String filePath = "data/org.ser";

Organisation org = new Organisation();

Employee emp = new Employee();

emp.setId("111");

emp.setName("Deba");

org.setEmp(emp);

/*

* Serialize the object graph

*/

storeObject(org, filePath);

/*

* De-serialize the object graph

*/

retrieveObject(filePath);

}

}

You can download the complete project from the following link.

https://www.dropbox.com/s/drkl2rqxizt1x3a/jbossserialization.zip

So we have achieved serialization of java object graph without implementing Serializable interface. There are certain benefits of using it.

  1. There is no need to implement Serializable interface.
  2. No need to define serialVersionUID.
  3. Since it uses the concept of smart cloning, the process of serialization if 10 times faster.

Conclusion

I hope you will enjoy my article on serialization. You can download and learn for your personal use only. For any queries contact me on [email protected].

References

http://www.jboss.org/serialization

http://www.jboss.org/file-access/default/members/serialization/downloads/jboss-serialization-1.0.3.GA.zip

http://mvnrepository.com/artifact/jboss/jboss-serialization/4.2.2.GA

http://en.wikipedia.org/wiki/Serialization

More Stories By Debadatta Mishra

Debadatta Mishra is a senior Java developer with five years of experience in the field of Java and related technologies. He has written many articles on Java-related technologies on the Internet.

Latest Stories
When you're operating multiple services in production, building out forensics tools such as monitoring and observability becomes essential. Unfortunately, it is a real challenge balancing priorities between building new features and tools to help pinpoint root causes. Linkerd provides many of the tools you need to tame the chaos of operating microservices in a cloud native world. Because Linkerd is a transparent proxy that runs alongside your application, there are no code changes required. I...
In his general session at 21st Cloud Expo, Greg Dumas, Calligo’s Vice President and G.M. of US operations, discussed the new Global Data Protection Regulation and how Calligo can help business stay compliant in digitally globalized world. Greg Dumas is Calligo's Vice President and G.M. of US operations. Calligo is an established service provider that provides an innovative platform for trusted cloud solutions. Calligo’s customers are typically most concerned about GDPR compliance, application p...
Modern software design has fundamentally changed how we manage applications, causing many to turn to containers as the new virtual machine for resource management. As container adoption grows beyond stateless applications to stateful workloads, the need for persistent storage is foundational - something customers routinely cite as a top pain point. In his session at @DevOpsSummit at 21st Cloud Expo, Bill Borsari, Head of Systems Engineering at Datera, explored how organizations can reap the bene...
"NetApp's vision is how we help organizations manage data - delivering the right data in the right place, in the right time, to the people who need it, and doing it agnostic to what the platform is," explained Josh Atwell, Developer Advocate for NetApp, in this SYS-CON.tv interview at 20th Cloud Expo, held June 6-8, 2017, at the Javits Center in New York City, NY.
At CloudEXPO Silicon Valley, June 24-26, 2019, Digital Transformation (DX) is a major focus with expanded DevOpsSUMMIT and FinTechEXPO programs within the DXWorldEXPO agenda. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive over the long term. A total of 88% of Fortune 500 companies from a generation ago are now out of business. Only 12% still survive. Similar percentages are found throug...
Druva is the global leader in Cloud Data Protection and Management, delivering the industry's first data management-as-a-service solution that aggregates data from endpoints, servers and cloud applications and leverages the public cloud to offer a single pane of glass to enable data protection, governance and intelligence-dramatically increasing the availability and visibility of business critical information, while reducing the risk, cost and complexity of managing and protecting it. Druva's...
Kubernetes as a Container Platform is becoming a de facto for every enterprise. In my interactions with enterprises adopting container platform, I come across common questions: - How does application security work on this platform? What all do I need to secure? - How do I implement security in pipelines? - What about vulnerabilities discovered at a later point in time? - What are newer technologies like Istio Service Mesh bring to table?In this session, I will be addressing these commonly asked ...
BMC has unmatched experience in IT management, supporting 92 of the Forbes Global 100, and earning recognition as an ITSM Gartner Magic Quadrant Leader for five years running. Our solutions offer speed, agility, and efficiency to tackle business challenges in the areas of service management, automation, operations, and the mainframe.
Blockchain has shifted from hype to reality across many industries including Financial Services, Supply Chain, Retail, Healthcare and Government. While traditional tech and crypto organizations are generally male dominated, women have embraced blockchain technology from its inception. This is no more evident than at companies where women occupy many of the blockchain roles and leadership positions. Join this panel to hear three women in blockchain share their experience and their POV on the futu...
The Jevons Paradox suggests that when technological advances increase efficiency of a resource, it results in an overall increase in consumption. Writing on the increased use of coal as a result of technological improvements, 19th-century economist William Stanley Jevons found that these improvements led to the development of new ways to utilize coal. In his session at 19th Cloud Expo, Mark Thiele, Chief Strategy Officer for Apcera, compared the Jevons Paradox to modern-day enterprise IT, examin...
With 10 simultaneous tracks, keynotes, general sessions and targeted breakout classes, @CloudEXPO and DXWorldEXPO are two of the most important technology events of the year. Since its launch over eight years ago, @CloudEXPO and DXWorldEXPO have presented a rock star faculty as well as showcased hundreds of sponsors and exhibitors! In this blog post, we provide 7 tips on how, as part of our world-class faculty, you can deliver one of the most popular sessions at our events. But before reading...
Cloud-Native thinking and Serverless Computing are now the norm in financial services, manufacturing, telco, healthcare, transportation, energy, media, entertainment, retail and other consumer industries, as well as the public sector. The widespread success of cloud computing is driving the DevOps revolution in enterprise IT. Now as never before, development teams must communicate and collaborate in a dynamic, 24/7/365 environment. There is no time to wait for long development cycles that pro...
DSR is a supplier of project management, consultancy services and IT solutions that increase effectiveness of a company's operations in the production sector. The company combines in-depth knowledge of international companies with expert knowledge utilising IT tools that support manufacturing and distribution processes. DSR ensures optimization and integration of internal processes which is necessary for companies to grow rapidly. The rapid growth is possible thanks, to specialized services an...
At CloudEXPO Silicon Valley, June 24-26, 2019, Digital Transformation (DX) is a major focus with expanded DevOpsSUMMIT and FinTechEXPO programs within the DXWorldEXPO agenda. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive over the long term. A total of 88% of Fortune 500 companies from a generation ago are now out of business. Only 12% still survive. Similar percentages are found throug...
Docker and Kubernetes are key elements of modern cloud native deployment automations. After building your microservices, common practice is to create docker images and create YAML files to automate the deployment with Docker and Kubernetes. Writing these YAMLs, Dockerfile descriptors are really painful and error prone.Ballerina is a new cloud-native programing language which understands the architecture around it - the compiler is environment aware of microservices directly deployable into infra...