Thursday, August 28, 2008

How to write a HTTP Service in JCAPS to send a file content

Few days back one of my friends asked my “How do we implement a HTTP Service to send a flat file content to the client?” of course using JCAPS. He wants me to do it in JCAPS5.1.3, so I did. Here I am sharing the logic I have used, so if any one of you has such requirement in future you can simply check this blog :-) . As you would have expected, i have used JCAPS's HTTP eWay(Adapter) for this exercise. If some one is new to HTTP eWay check this Link for documentation. I chose Java Collaboration to implement the HTTP Service(Alternatively we can use the Business Process also to accomplish the same). Below is the problem statement and the steps i have followed to implement the HTTP Service using HTTP eWay in JCAPS 5.1.3.

Problem Statement:

Implement a HTTP service which accepts the file name (should exists in a local file system - server) and send the file content as a response.


1.) Create a project in eDesigner, i gave the project name as 'prjHTTPService'.

2.) Create a Java Collaboration (jcd) with name 'jcdHTTPService'. In the second step of Collaboration Wizard, select the repository(HEAD)-->Sun SeeBeyond-->eWays-->HTTPServer-->processRequest as the 'Web Service Operation' to implement.

3.) Optionally add any otds that you think will be required to implement the service. For this example i have not used any otds because i am just reading the file data(using java.io) and sending it as a response. Finally click on Finish button to create the jcd.

4.) Open the 'Java Source' editor for above jcd and put the logic given in below screenshot.




5.) As its mentioned in the line#24 (in above screen shot) we need to set the 'Content Type' property of the HTTP Response to the respective MIME type of the file content(plain text, XML, html, etc ....)

6.) My code above is assuming only one request parameter in the input HTTP request, that is why i am reading the file name through index position( input.getRequest().getParameterInfo().getWebParameterList( 0 ).getValues( 0 ) ). If there are more than one request parameters in the HTTP request this logic need to be changed( we can get it through request attribute name also, for more info refer HTTPRequest java docs)

7.) readFileInfo() method is a utility method i have written using java.io to read the file content(screenshot is pasted below). Alternately we can use BatchLocalFile eWay also for this purpose but i don't prefer this approach for such a simple tasks.

Note:- This method will work only for the files whose data can be read as a meaningful String. If some one want to send a file content which can not be read as a String, this logic needs to be changed a little bit(by using Bytes instead of String).




8.) That is it for the logic. Create the Connectivity Map and Deployment profile for the project and deploy it. In case of any problem in setting the configurations parameters in Connectivity Map and Deployment Profile Refer Sun SeeBeyond eWay(TM) HTTPS Adapter User's Guide.

9.) To test the project, open the url "http://<Host Name>:<port>/<Deployment Profile Name>_servlet_<servlet-url property value given in Connectivity Map>/<servlet-url property value given in Connectivity Map>?FileName=<FileName>" in the web browser, the browser should show the file content.

Hope this helps :-) in case of any problems just drop me a mail to srinivasa.mataboyina@sun.com or to srinivasarao.mataboyina@gmail.com. I am happy to help on this.

Check my Next blog "How to Write a HTTP Client in JCAPS to get a file content"

1 comment:

Vivek said...

Could you please give the step by step description assuming it will be done by a novice developer?