Code
What is REST ?
Rest=Representational state transfer which is an architecture design to represent the resources. Rest provide the uniform interface through additional constraints around how to identify resources, how to manipulate resources through representations, and how to include metadata that make messages self-describing.
Rest is not tied with any platform and technology but WEB is only platform which satisfy the all constrain. So any thing you build using Rest constrain, you do it on Web using HTTP.
Following are the HTTP methods which are use full when creating Rest Services.
HTTP Mehtods
Designing of the URI
To designing Rest services you need to design URI, so for that you need to list out the resources that going to be exposed by the service. As I am going to design Employee Create,updae and select service, so resource is
http://localhost/restservices/MyRestServices.svc
In below discussion I am going to design the URL presentation for each operation
http://localhost/restservices/MyRestServices.svc/Employees
But there are no. of Employee in system and to apply filter on Employees
http://localhost/restservices/MyRestServices.svc/Employees?type = {type}
Note : In above url get list of employee of the type specified {type} of url.
To Get single Emplyee by using uniqid of Employee.
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeesID}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
Extension to above scenario, If want to get employee by using id with the type
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeesID}?type = {type}
http://localhost/restservices/MyRestServices.svc/Employees/{employeeid}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
http://localhost/restservices/MyRestServices.svc/Employees/{employeeid}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeeID}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
As you can see here the URL for Create, Update and Delete are same but it makes actual difference when you combile this URL with specific HTTP methods.
Now Combine the url(s) with the HTTP methods
List Employees
Delete Employee
Designing WCF with REST
Article link to get understanding about WCF service : Create, Host(Self Hosting, IIS hosting) and Consume WCF servcie
To design Rest WCF service first start to design Class to represent Employee
Now start with Creation of WCF service which going to serve data to the client i.e going to work as REST full service.
You need to decorate each method in your Servercie interface with the WebInvoke attribute in addition to OperationContract, which allows user to bind method with UrlTemplate and HTTP method. Lets look the each method of interface one by one
Following methods serve data which is requested using GET method of HTTP.
Following method allow to insert new data and update existed using HTTP method PUT.
Delete Mehtod
Method allow to remove data using HTTP method DELETE.
Consume WCF RESTfull service
Before you start following reading below its better to know that how to configure and consume WCF service using jQuery : Steps to Call WCF Service using jQuery
Below is jQuery code to consume web service.
GetEmployee
Service1.svc/Employees/1
in this 1 is employeeid that which is example in turn this function call the RESTfull service function which is having URLTemplate Employees/{Employee_Id} and method type is POST.
CreateEmployee
Service1.svc/Employees/Denny
in this 0 is employeeID (0 because I am creating new employee) that which is example in turn this function call the RESTfull service function which is having url template Employees/{Employee_Id} and method type is POST.
In the createemployee method I am creating Employee object with the property require which is going to be consume by service to create employee.
The following code checks the result.GetUserResult statement, so your result object gets the property your service method name + Result. Otherwise, it will give an error like object not found in Javascript.
Summary
Its quite easy to Create RESTfull service using .net WCF framework. But it must require to understand how you represent your resource i.e design URL template to represent your resource on WEB.
What is REST ?
Rest=Representational state transfer which is an architecture design to represent the resources. Rest provide the uniform interface through additional constraints around how to identify resources, how to manipulate resources through representations, and how to include metadata that make messages self-describing.
Rest is not tied with any platform and technology but WEB is only platform which satisfy the all constrain. So any thing you build using Rest constrain, you do it on Web using HTTP.
Following are the HTTP methods which are use full when creating Rest Services.
HTTP Mehtods
- GET - Requests a specific representation of a resource
- PUT - Create or update a ersoure with the supplied representation
- DELETE - Deletes the specified resource
- POST - Submits data to be processed by the identified resource
- HEAD - Similar to GET but only retrieves headers and not the body
- OPTIONS - Returns the methods supported by the identified resource
Designing of the URI
To designing Rest services you need to design URI, so for that you need to list out the resources that going to be exposed by the service. As I am going to design Employee Create,updae and select service, so resource is
- Employee
- List of Employees
- A Employee by Id
- Create Employee
- Update Employee
- Delete Employee
http://localhost/restservices/MyRestServices.svc
In below discussion I am going to design the URL presentation for each operation
- List Employees
http://localhost/restservices/MyRestServices.svc/Employees
But there are no. of Employee in system and to apply filter on Employees
http://localhost/restservices/MyRestServices.svc/Employees?type = {type}
Note : In above url get list of employee of the type specified {type} of url.
To Get single Emplyee by using uniqid of Employee.
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeesID}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
Extension to above scenario, If want to get employee by using id with the type
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeesID}?type = {type}
- Create Employee
http://localhost/restservices/MyRestServices.svc/Employees/{employeeid}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
- Update Employee
http://localhost/restservices/MyRestServices.svc/Employees/{employeeid}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
- Delete Employee
http://localhost/restservices/MyRestServices.svc/Employees/{EmployeeID}
Note : In above URL {EmployeesID} is get replaced by ID of Employee.
As you can see here the URL for Create, Update and Delete are same but it makes actual difference when you combile this URL with specific HTTP methods.
Now Combine the url(s) with the HTTP methods
List Employees
- GET - http://localhost/restservices/MyRestServices.svc/Employees
- PUT - http://localhost/restservices/MyRestServices.svc/Employees/{employeeid}
Delete Employee
- DELETE - http://localhost/restservices/MyRestServices.svc/Employees/{EmployeeID}
Designing WCF with REST
Article link to get understanding about WCF service : Create, Host(Self Hosting, IIS hosting) and Consume WCF servcie
To design Rest WCF service first start to design Class to represent Employee
[DataContract] public class Employee { [DataMember] public string Employeename { get; set; } [DataMember] public string Designation { get; set; } [DataMember] public string Address { get; set; } [DataMember] public string Email { get; set; } }as you see Employee class DataContaract attribute so that is going to serve data to client i.e going to work as data exchanger.
Now start with Creation of WCF service which going to serve data to the client i.e going to work as REST full service.
You need to decorate each method in your Servercie interface with the WebInvoke attribute in addition to OperationContract, which allows user to bind method with UrlTemplate and HTTP method. Lets look the each method of interface one by one
public interface IService1 {Get Methods
Following methods serve data which is requested using GET method of HTTP.
- GetEmployees
[WebInvoke(Method = "POST", ResponseFormat = WebMessageFormat.Json,UriTemplate = "?tag={tag}")] [OperationContract] Employees GetEmployees(string tag);
- GetEmployee
Allow to get the employee with specific id. "Employee_id" of the uritemplate get replace with the employeeid.
[WebInvoke(Method = "POST", ResponseFormat = WebMessageFormat.Json, UriTemplate = "Employees/{Employee_id}")] [OperationContract] Employee GetEmployee(string Employee_id);Create and Update Method
Following method allow to insert new data and update existed using HTTP method PUT.
- PutEmployeeAccount
[WebInvoke(Method = "PUT", ResponseFormat = WebMessageFormat.Json, UriTemplate = "Employees/{Employee_Id}")] [OperationContract] string PutEmployeeAccount(Employee Employeeobj,string Employeename );
Delete Mehtod
Method allow to remove data using HTTP method DELETE.
- DeleteEmployeeAccount
[WebInvoke(Method = "DELETE", UriTemplate = "Employees/{Employee_Id}")] [OperationContract] void DeleteEmployeeAccount(string Employeename); }WebInvoke
- The WebInvokeAttribute determines what HTTP method that a service operation responds to I.e Http post, get or delete.
- Indicates a service operation is logically an invoke operation and that it can be called by the REST programming model.
- An URI template is a URI-like String that contained variables marked of in braces ({, }), which provides a consistent way for building and parsing URIs based on patterns.
- UriTemplates are composed of a path and a query. A path consists of a series of segments delimited by a slash (/). Each segment can have a literal value, a variable value (written within curly braces [{ }] .query part is optional. If present, it specifies same way as querystring name/value pairs. Elements of the query expression can be presented as (?x=2) or variable pairs (?x={val}).
- One of the reason to add this class in .net is to support the REST architectural style used by developers today.
Consume WCF RESTfull service
Before you start following reading below its better to know that how to configure and consume WCF service using jQuery : Steps to Call WCF Service using jQuery
Below is jQuery code to consume web service.
var Type; var Url; var Data; var ContentType; var DataType; var ProcessData; var method; //Generic function to call WCF Service function CallService() { $.ajax({ type: Type, //GET or POST or PUT or DELETE verb url: Url, // Location of the service data: Data, //Data sent to server contentType: ContentType, // content type sent to server dataType: DataType, //Expected data format from server processdata: ProcessData, //True or False success: function(msg) {//On Successfull service call ServiceSucceeded(msg); }, error: ServiceFailed// When Service call fails }); } function ServiceFailed(result) { alert('Service call failed: ' + result.status + '' + result.statusText); Type = null; Url = null; Data = null; ContentType = null; DataType = null; ProcessData = null; }Code above declare and initializes variables which are defined above to make a call to the service. CallService function sent request to service by setting data in $.ajax
GetEmployee
function GetEmployee() { var uesrid = "1"; Type = "POST"; Url = "Service1.svc/Employees/1"; ContentType = "application/json; charset=utf-8"; DataType = "json"; ProcessData = false; method = "GetEmployee"; CallService(); }GetEmployee method used to get employee with specific id. URL to make call to service is
Service1.svc/Employees/1
in this 1 is employeeid that which is example in turn this function call the RESTfull service function which is having URLTemplate Employees/{Employee_Id} and method type is POST.
CreateEmployee
function CreateEmployee() { Type = "PUT"; Url = "Service1.svc/Employees/0"; var msg2 = { "Employeename": "Denny", "Designation": "engg.", "Address": "vadodara", "Email": "pr@ab.com" }; Data = JSON.stringify(msg2); ContentType = "application/json; charset=utf-8"; DataType = "json"; ProcessData = true; method = "CreateEmployee"; CallService(); }this method used to create employee. URL to make call to service is
Service1.svc/Employees/Denny
in this 0 is employeeID (0 because I am creating new employee) that which is example in turn this function call the RESTfull service function which is having url template Employees/{Employee_Id} and method type is POST.
In the createemployee method I am creating Employee object with the property require which is going to be consume by service to create employee.
The following code checks the result.GetUserResult statement, so your result object gets the property your service method name + Result. Otherwise, it will give an error like object not found in Javascript.
function ServiceSucceeded(result) { if (DataType == "json") { if(method == "CreateEmployee") { alert(result); } else { resultObject = result.GetEmployeeResult; var string = result.Employeename + " \n " + result.Designation + " \n " + result.Address + " \n " + result.Email; alert(string); } } } function ServiceFailed(xhr) { alert(xhr.responseText); if (xhr.responseText) { var err = xhr.responseText; if (err) error(err); else error({ Message: "Unknown server error." }) } return; } $(document).ready( function() { CreateEmployee(); } );So in this article I am just showed example of CreateEmployee and GetEmployee because this is enough to understand how to consume the method of WCF RESTfull service. Now can create other methods by downloading code and to understand it better way.
Summary
Its quite easy to Create RESTfull service using .net WCF framework. But it must require to understand how you represent your resource i.e design URL template to represent your resource on WEB.
Beautiful post, mnogosmyslenny ...
ReplyDeleteYou should talk about Cross Domain problem with JSONP and Allow Options
ReplyDeleteWhere is the code
ReplyDeleteFrom the last couple of days I was learning REST API in C#.NET.
ReplyDeleteI have successfully created some methods.
But I have got the following requirement
campaigns.svc/xml/apikey/filters?parameter=value¶meter2=value2/start/limit
so, in the above we are sending four parameters
1. KEY
2. Filter options
3. Start value
4. Limit value
Can I know how to build a method, where I can access set of FILTER options
From the last couple of days I was learning REST API in C#.NET.
ReplyDeleteI have successfully created some methods.
But I have got the following requirement
campaigns.svc/xml/apikey/filters?parameter=value¶meter2=value2/start/limit
so, in the above we are sending four parameters
1. KEY
2. Filter options
3. Start value
4. Limit value
Can I know how to build a method, where I can access set of FILTER options
Hey,
ReplyDeleteI am having some trouble in fetching JSON string from WCF Service via JQuery.
http://stackoverflow.com/questions/9546338/unable-to-return-json-string-from-wcf-service-from-jquery#comment12097852_9546338
Please help.
Salil
What changes should I do for JSONP? In case of JSONP, my wcf service always returns failed. Any idea?
ReplyDelete"Following methods serve data which is requested using GET method of HTTP."
ReplyDeleteThen you use Method="POST"
Code download link is not working..
ReplyDeleteCan you please let me know how to use WCF rest using xml as input from Jquery
ReplyDeletevikas
Nice explanation but can't seem to see where you consumed the var method in the ajax call ?
ReplyDeletefunction CallService() {
$.ajax({
type: Type, //GET or POST or PUT or DELETE verb
url: Url, // Location of the service
data: Data, //Data sent to server
contentType: ContentType, // content type sent to server
dataType: DataType, //Expected data format from server
processdata: ProcessData, //True or False
success: function(msg) {//On Successfull service call
ServiceSucceeded(msg);
},
error: ServiceFailed// When Service call fails
});
}