Skip to main content

Recommended framework for Java Web Services



With an abundance of frameworks and stacks for Java Web Services (Axis2, Spring WS, CFX, Metro, ...), which one should be selected for new projects? What are the pros and cons for each one? How well have they worked for you?





See related Q here


Comments

  1. We are using a "Java first" approach. This means we generate our Java classes, and then use the web services framework to dynamically generate WSDL from those classes. The alternative is "WSDL First", where you use tools to generate Java stub code from the WSDL and XSD.

    If you like the Java-first approach, I can recommend CXF as a reliable framework for quick creation of web services. It works well.

    For now I have/had 3 issues with CXF:


    One of pitfall that me wet was a data binding. Standard JAXB data binding works only in simple cases without additional tuning. Because of that we decided switch to native CXF data binding Aegis.
    A minor but annoying issue exists with the use of Collections in a POJO classe exposed as a web service. Classes that you plan to put into Collections must implement Comparable interface otherwise you'll get a strange runtime exception.
    You can't have both CXF and it's predecessor XFire library in your classpath. Not sure that it's important for you, but it can be sufficient for an upgrade from XFire to CXF.


    And my last point that isn't directly related to CXF. If you plan to call web services through Mule 2.x ESB (as we are) you can find that it's not as easy as it was with Mule 1.x and XFire.

    Update: New issue that you can meet calling WS throw the CXF API. If your WS is shielded by HTTP basic authentication (i.e. username and password) and you call WS using a dynamic proxy, you most probably will get a 401 error (authentication challenge). Workaround described here.

    Regarding Spring WS, AFAIK it's wsdl first approach. If you like it, possible it's your case.

    ReplyDelete
  2. In a recent project we are using Spring Web Services. I do like it - it is quite easy to use, well documented and flexible as well. Of course, it makes the most sense to use it if you are using Spring for your application, anyway.

    I have tried Axis, Axis2 and Spring WS so far - I do like Spring the most and I think it is the easiest to use, once you understood how Spring itself works. (Except that you do have a nice "create webservice project with Axis/Axis2" wizard in eclipse, which you don't have with Spring.) Axis2 wasn't too well documented the time I tried it, but this might have changed.

    ReplyDelete
  3. Jersey: https://jersey.dev.java.net/

    I have not used it myself, but it seems very simple to get up and running.

    ReplyDelete
  4. A nice thing about Metro is the support for streaming large files, which solves a problem that is often brough up against Web Services in general.

    ReplyDelete
  5. I just came across a web service framework called enunciate from codehaus.

    I've done a prototype application for work and REALLY like how easy it was, all the nice additional features & the configuration options.

    Supports SOAP, RESTful and JSON endpoints.
    Generates tons of good documentation and a variety of client libraries for JDK 1.4, or 6.

    You can choose which framework you'd like to leverage for the service - Apache, JAX-WS... I'm going to use XFire.

    http://enunciate.codehaus.org

    Check out the Getting Started Guide. Includes output samples and real-world examples, not just another Hello World

    ReplyDelete
  6. I personally use Axis 2.

    For the pros it's very simple to write a service : create a class with method -> generate WSDL from Java (Java2WSDL in axis) -> generate client code (WSDL2Java)
    to deploy the service you can use the axis webapp (in any servlet container), package the service class with an extra services.xml into a file *.aar (the services.xml is not very hard to write) and put the service in the axis webapp (putting the file in the services/ directory or via an administration page in the axis webapp)
    For a simple webservice it's very simple

    For the cons, well the documentation is not very reach. I had many trouble for implementation of WS-Security as the "rampart" module is missing example in my opinion, I had to buy a book...

    ReplyDelete
  7. XFire, the precursor to CXF, is great for systems forced to use Java 1.4. I have no idea if CXF is any good, the whole API changed. XFire's API was much easier for me to understand compared with a cursory glance at CXF's API. However, you have to jump through hoops to override defaults in certain situations sometimes.

    ReplyDelete
  8. I would recoomend axis2 IF you decide to use eclipse as your ide. Using the webtools project and the axis2 service archiver you have pretty much everything you need. You can simple write a set of functions you would like for your webservice and than generate a webservice, so there ist literarry no learning curve you write just the things you want and it works. The client is also simple, the only thing you will have to get your head around is generating a stub which will call your webservice. I personally tried CXF and axis2 is in my oppinion easier and more hands on approach.

    ReplyDelete
  9. Spring Web Service is good choice for new projects. It is easy to use and you can find lots of documents about it.

    ReplyDelete
  10. I've been using Spring Web Services (both client-side and server-side) for the past several months and have been pretty satisfied with it. Started with a schema and wsdl supplied by a third-party, so the contract-first approach was a natural fit. The documentation is reasonably good and the framework is pretty easy to use and configure. For my needs, using JAXB 2 and AbstractValidatingMarshallingPayloadEndpoint has worked well. I found the Validator component simple to use. I had a requirement to use an x.509 cert on the client-side, which was not too difficult to configure using the Wss4jSecurityInterceptor. The framework mostly abstracts away the underlying http layer, but at one point I needed to access the HttpServletResponse from my web services code to set an http response header. After a bit of searching, I was able to do this via the TransportContextHolder's getTransportConext() static method.

    ReplyDelete
  11. You have to look at HybridJava. Full documentation is less than 15 pages, so you may read it all yourself in an hour.

    ReplyDelete
  12. See a comparison of Axis2, CXF and JAX-WS.

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.