I am seeing a lot of new web services are implemented using a REST style architecture these days rather than a SOAP one. Lets step back a second and explain what REST is.
What is a REST Web Service
The acronym REST stands for Representational State Transfer, this basically means that each unique URL is a representation of some object. You can get the contents of that object using an HTTP GET, to delete it, you then might use a POST, PUT, or DELETE to modify the object (in practice most of the services use a POST for this).
Who's using REST?
All of Yahoo's web services use REST, including Flickr, del.icio.us API uses it, pubsub, bloglines, technorati, and both eBay, and Amazon have web services for both REST and SOAP.
Who's using SOAP?
Google seams to be consistent in implementing their web services to use SOAP, with the exception of Blogger, which uses XML-RPC. You will find SOAP web services in lots of enterprise software as well.
REST vs SOAP
As you may have noticed the companies I mentioned that are using REST api's haven't been around for very long, and their apis came out this year mostly. So REST is definitely the trendy way to create a web service, if creating web services could ever be trendy (lets face it you use soap to wash, and you rest when your tired). The main advantages of REST web services are:
Lightweight - not a lot of extra xml markup Human Readable Results Easy to build - no toolkits required SOAP also has some advantages:
Easy to consume - sometimes Rigid - type checking, adheres to a contract Development tools For consuming web services, its sometimes a toss up between which is easier. For instance Google's AdWords web service is really hard to consume (in CF anyways), it uses SOAP headers, and a number of other things that make it kind of difficult. On the converse, Amazon's REST web service can sometimes be tricky to parse because it can be highly nested, and the result schema can vary quite a bit based on what you search for.
Which ever architecture you choose make sure its easy for developers to access it, and well documented.
Tuesday, August 27, 2013
REST vs SOAP Web Services
Tuesday, July 2, 2013
Difference between HQL and Criteria Query in Hibernate
Criteria, in theory should have less overhead than an HQL query
(except for named queries, which I'll get to). This is because Criteria
doesn't need to parse anything. HQL queries are parsed with an
ANTLR-based parser and then the resulting AST is turned into SQL.
However, with HQL/JPAQL you can define named queries, where the SQL is
generated when the
SessionFactory starts up. In theory, named queries have less overhead
than Criteria.
So, in terms of SQL-generation overhead we have:
Here are the things I consider when deciding between Criteria and HQL/JPAQL:
So, in terms of SQL-generation overhead we have:
- Named HQL/JPAQL Query - SQL generation happens only once.
- Criteria - No need to parse before generating.
- (non-named) HQL/JPAQL Query - Parse, then generate.
Here are the things I consider when deciding between Criteria and HQL/JPAQL:
- First, you have to decide if you're OK with having a dependency on Hibernate-proprietary API in your code. JPA doesn't have Criteria.
- Criteria is really good at handling many optional search parameters such as you might find on a typical web page with a multi-parameter 'search form'. With HQL, developers tend to tack on where clause expressions with StringBuilder (avoid this!). With Criteria, you don't need to do that.
- HQL/JPAQL can be used for most other things, because the code tends to be smaller and easier for developers to understand.
- Really frequent queries can be turned into named queries if you use HQL. I prefer to do this later, after some profiling.
Subscribe to:
Posts (Atom)