Welcome!

Java IoT Authors: Pat Romanski, Yeshim Deniz, Liz McMillan, Zakia Bouachraoui, Courtney Abud

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.

IoT & Smart Cities Stories
As the fourth industrial revolution continues to march forward, key questions remain related to the protection of software, cloud, AI, and automation intellectual property. Recent developments in Supreme Court and lower court case law will be reviewed to explain the intricacies of what inventions are eligible for patent protection, how copyright law may be used to protect application programming interfaces (APIs), and the extent to which trademark and trade secret law may have expanded relev...
After years of investments and acquisitions, CloudBlue was created with the goal of building the world's only hyperscale digital platform with an increasingly infinite ecosystem and proven go-to-market services. The result? An unmatched platform that helps customers streamline cloud operations, save time and money, and revolutionize their businesses overnight. Today, the platform operates in more than 45 countries and powers more than 200 of the world's largest cloud marketplaces, managing mo...
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...
When Enterprises started adopting Hadoop-based Big Data environments over the last ten years, they were mainly on-premise deployments. Organizations would spin up and manage large Hadoop clusters, where they would funnel exabytes or petabytes of unstructured data.However, over the last few years the economics of maintaining this enormous infrastructure compared with the elastic scalability of viable cloud options has changed this equation. The growth of cloud storage, cloud-managed big data e...
The platform combines the strengths of Singtel's extensive, intelligent network capabilities with Microsoft's cloud expertise to create a unique solution that sets new standards for IoT applications," said Mr Diomedes Kastanis, Head of IoT at Singtel. "Our solution provides speed, transparency and flexibility, paving the way for a more pervasive use of IoT to accelerate enterprises' digitalisation efforts. AI-powered intelligent connectivity over Microsoft Azure will be the fastest connected pat...
Your applications have evolved, your computing needs are changing, and your servers have become more and more dense. But your data center hasn't changed so you can't get the benefits of cheaper, better, smaller, faster... until now. Colovore is Silicon Valley's premier provider of high-density colocation solutions that are a perfect fit for companies operating modern, high-performance hardware. No other Bay Area colo provider can match our density, operating efficiency, and ease of scalability.
CloudEXPO has been the M&A capital for Cloud companies for more than a decade with memorable acquisition news stories which came out of CloudEXPO expo floor. DevOpsSUMMIT New York faculty member Greg Bledsoe shared his views on IBM's Red Hat acquisition live from NASDAQ floor. Acquisition news was announced during CloudEXPO New York which took place November 12-13, 2019 in New York City.
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...
Atmosera delivers modern cloud services that maximize the advantages of cloud-based infrastructures. Offering private, hybrid, and public cloud solutions, Atmosera works closely with customers to engineer, deploy, and operate cloud architectures with advanced services that deliver strategic business outcomes. Atmosera's expertise simplifies the process of cloud transformation and our 20+ years of experience managing complex IT environments provides our customers with the confidence and trust tha...
The graph represents a network of 1,329 Twitter users whose recent tweets contained "#DevOps", or who were replied to or mentioned in those tweets, taken from a data set limited to a maximum of 18,000 tweets. The network was obtained from Twitter on Thursday, 10 January 2019 at 23:50 UTC. The tweets in the network were tweeted over the 7-hour, 6-minute period from Thursday, 10 January 2019 at 16:29 UTC to Thursday, 10 January 2019 at 23:36 UTC. Additional tweets that were mentioned in this...