"We wondered why people were so against using regular objects in their systems and concluded that it was because simple objects lacked a fancy name. So we gave them one, and it's caught on very nicely."
The term "POJO" initially denoted a Java object which does not follow any of the major Java object models, conventions, or frameworks; nowadays "POJO" may be used as an acronym for plain old JavaScript object as well, in which case the term denotes a JavaScript object of similar pedigree. The term continues the pattern of older terms for technologies that do not use fancy new features, such as plain old Ruby object in Ruby, plain old telephone service in telephony and Plain Old Documentation in Perl. The equivalent to POJO on the.NET framework is plain Old CLR object. For PHP, it is plain old PHP object. The POJO phenomenon has most likely gained widespread acceptance because of the need for a common and easily understood term that contrasts with complicated object frameworks.
Definition
Ideally speaking, a POJO is a Java object not bound by any restriction other than those forced by the Java Language Specification; i.e. a POJO should not have to
Extend prespecified classes, as inpublic class Foo extends javax.servlet.http.HttpServlet
Contextual variations
JavaBeans
A JavaBean is a POJO that is serializable, has a no-argument constructor, and allows access to properties using getter and setter methods that follow a simple naming convention. Because of this convention, simple declarative references can be made to the properties of arbitrary JavaBeans. Code using such a declarative reference does not have to know anything about the type of the bean, and the bean can be used with many frameworks without these frameworks having to know the exact type of the bean. The JavaBeans specification, if fully implemented, slightly breaks the POJO model as the class must implement the Serializable interface to be a true JavaBean. Many POJO classes still called JavaBeans do not meet this requirement. Since Serializable is a marker interface, this is not much of a burden. The following shows an example of a JavaServer Faces component having a bidirectional binding to a POJO's property:
The definition of the POJO can be as follows: public class MyBean
Because of the JavaBean naming conventions the single "someProperty" reference can be automatically translated to the "getSomeProperty" method for getting a value, and to the "setSomeProperty" method for setting a value.
Transparently adding services
As designs using POJOs have become more commonly used, systems have arisen that give POJOs the full functionality used in frameworks and more choice about which areas of functionality are actually needed. In this model, the programmer creates nothing more than a POJO. This POJO purely focuses on business logic and has no dependencies on frameworks. Aspect-oriented programming frameworks then transparently add cross-cutting concerns like persistence, transactions, security, and so on. Spring was an early implementation of this idea and one of the driving forces behind popularizing this model. An example of an EJB bean being a POJO:
The following shows a fully functional EJB bean, demonstrating how EJB3 leverages the POJO model: public class HelloWorldService
As given, the bean does not need to extend any EJB class or implement any EJB interface and also does not need to contain any EJB annotations. Instead, the programmer declares in an externalXML file which EJB services should be added to the bean: helloWorld com.example.HelloWorldService stateless
In practice, some people find annotations elegant, while they see XML as verbose, ugly and hard to maintain, yet others find annotations pollute the POJO model. Thus, as an alternative to XML, many frameworks allow annotations to be used instead of or in addition to XML. The following shows the same EJB bean as showed above but with an annotation added. In this case the XML file is no longer needed: @Stateless public class HelloWorldService
With the annotation as given above the bean isn't a truly pure POJO anymore, but since annotations are merely passive metadata this has far fewer harmful drawbacks compared to the invasiveness of having to extend classes and/or implement interfaces. Accordingly, the programming model is still very much like the pure POJO model.