DOZER Framework and JCAPS512
Given the multilayered nature of the applications following SOA architectural approach,it becomes imperative that the message model being used in one layer is not bleeded in to other layers so that the layers are loose coupled.If we want to acheive the reusability of the business logic effectively,let the mapping functionality between different message models be segregated from the business logic and be handled by a mapping framework.
Advantages of using a mapping framework
- Helps in providing more emphasis on business logic rather than focussing on the mapping intricasies by bifurcating the mapping functionality from the business logic.
- Ease to maintain.
- Ease to map.
- Mapping between various data structures,Deep mapping,Mapping based on the indexes.
Lets take an example to showcase the usage of the mapping framework in JCAPS512 environment
Objective:Service(implemented using a JCD) needs to invoke another service by passing an object(java object,lets call it as a target object).The target object needs to be populated with the values passed on from source system which is unmarshalled in to an OTD being used in the JCD metioned above.The response from the target service is mapped to an output OTD in the source service(JCD) and send to an appropriate destination.
This can be implemented in the following way
1)Populate the input OTD with the message from the source system.
2)Using DOZER framework map the fields from the input OTD to that of the target object expected by the target service.
3)Map the output from the target service to the output OTD using DOZER framework.
Make the following code singleton
MapperIF mapper = new DozerBeanMapper();
DestinationObject destObject = (DestinationObject)mapper.map(otdObject,DestinationObject.class);
//set or get the values using the destObject object
Sample mapping file for mapping between source and target fields
DestinationFieldName