Here in Android Tutorial Blog, we have already discussed lot about using Webservice in Android applications. Take a look at Android Webservice Tutorial to know list of articles we wrote on webservice.java
Integrating Android application and Webservice is not that much difficult. We can make it work if we know basics of webservice and the procedure to make webservice call from inside Android applications.android
In this post, I will be discussing about creating and invoking RESTful webservice in Android applications.
This tutorial will be published as three parts:web
Part 1 – Introduction to RESTful webservicerestful
Part 2 – How to create RESTFul webservice in Java?app
Part 3 – How to invoke RESTful webservice in Android applications?less
REST describes a set of architectural principles by which data can be transmitted over a standardized interface (such as HTTP). The acronym REST stands for Representational State Transfer, this basically means that each unique URL is a representation of some object.dom
REST asks developers to use HTTP methods explicitly and in a way that’s consistent with the protocol definition. This basic REST design principle establishes a one-to-one mapping between create, read, update, and delete (CRUD) operations and HTTP methods. According to this mapping:ide
To create a resource on the server, use POST.
To retrieve a resource, use GET.
To change the state of a resource or to update it, use PUT.
To remove or delete a resource, use DELETE.post
For example:flex
http://weatherinfo.org/getweather/mumbai – It gets the weather information of Mumbai (one of the Indian cities)
http://employer.com/update/salary/130/3000 – It updates Salary of Employee with Employee ID ’130′ as $3000.
http://countries.com/add/singapore – It adds country ‘Singapore’ to the list of Countries
http://product.com/delete/dell/inspiron15r – It deletes Dell Inspiron 15R from the list of products
[Domain names mentioned above are just for examples, they are not working domains]
Internet giants like Yahoo, Amazon, eBay and more are using Restful webservice
REST | SOAP |
REST stands for REpresentational State Transfer | SOAP stands for Simple Object Access Protocol |
REST is not XML protocol based | SOAP is a XML based messaging protocol |
REST doesn’t have any specification | SOAP has specifications like WSDL etc |
REST doesn’t enforce message format as XML or JSON | SOAP enforces message format as XML |
Light weight – due to the usage of JSON | Heavy weight – due to the usage of XML |
Easy to parse the response | Bit difficult to parse the response |
Fist step in designing RESTFul webservice is choosing the right domain name – say weatherinfo.org to retrieve weather information of cities.
Let us take the first example (weatherinfo.org) which takes city name as input, composes weather information of the city and respond back to the browser. Assume the response is in XML format, this can be in other formats like JSON as well.
Here is the structure of Request and Response:
HTTP Request
The client request from the browser will look like:
1
|
GET http://weatherinfo.org/getweather/mumbai HTTP/1.1
|
HTTP Response
The server response will look like
1
2
3
4
5
6
7
8
9
|
HTTP/1.1 200 Ok
Date: Mon, 14 Apr 2014 10:20:58 GMT
Content-Type: text/xml
Content-length: 139
<
City
name
=
"Mumbai"
datetime
=
"2014-04-14 10:20:58 GMT"
>
<
Condition
>Scattered Clouds</
Condition
>
<
Temp
>33</
Temp
>
</
City
>
|
Line 1 is the initial line which has the HTTP response code – 200 OK, lines 2 through 4 are the HTTP headers (there can be lots of headers, only 3 are shown here), line 5 is the mandatory blank line separating header and body, and lines 6 through 10 constitute the 「HTTP Body (or content)」 – this part is the data that the response carries and can be in any format, not necessarily XML.
In fact, the most commonly used format on the web is HTML – one that web servers use to send back data to browsers. Whatever it is, the 「Content-type」 header usually specifies it. But if you are writing a web service, JSON is a better choice, but that is upto me. If your web service does not return complex or composite data, the format does not need to be JSON – it can be plain , in which case the body will just be a string of characters.
RESTful Web services are designed with less dependence on proprietary middleware (for example, an application server) than the SOAP- and WSDL-based kind.
As per the RESTful interface design, XML or JSON over HTTP is a powerful interface that allows internal applications, such as Asynchronous JavaScript + XML/JSON (Ajax)-based custom user interfaces, to easily connect, address, and consume resources.
The great fit between Ajax and REST has increased the amount of attention REST is getting these days.
Exposing a system’s resources through a RESTful API is a flexible way to provide different kinds of applications with data formatted in a standard way. It helps to meet integration requirements that are critical to building systems where data can be easily combined (mashups) and to extend or build on a set of base, RESTful services into something much bigger.