Click here to Skip to main content
11,924,825 members (55,412 online)
Click here to Skip to main content
Add your own
alternative version

Tagged as


78 bookmarked

Restful Crud Operation on a WCF Service

, 3 Oct 2010 CPOL
Rate this:
Please Sign up or sign in to vote.
In this article, I have introduced how easily you can create a RESTful service in WCF


WCF is beginning to gain popularity day by day. Many of us build services using WCF and want other applications made on different architecture (from Java, PHP, etc.) to communicate or inter operate with each other. REST or Representational State Transfer is a Design Pattern to build a service so that it works the same way as any normal service but it will eventually use Web Request - Response mechanism to communicate between client and server rather than SOAP messages. In this post, I will give you a step by step approach of how you could build your own WCF service using REST.

REST abbreviated as Representational State Transfer is coined by Roy Fielding is a Design pattern for Networked system. In this pattern, the Client invokes a Web request using an URL, so the basics of REST pattern is to generate a unique URI to represent data.


If you look into Roy Fielding's quote on REST, it says:

"Representational State Transfer is intended to evoke an image of how a well-designed Web application behaves: a network of web pages (a virtual state-machine), where the user progresses through an application by selecting links (state transitions), resulting in the next page (representing the next state of the application) being transferred to the user and rendered for their use."

That means REST is intended for Web applications where the browser invokes each request by specifying unique URI.


There are a few basic thoughts behind the implementation of REST services. Let's look into it:

  • Web is very simple and successful.
  • Web Standards are fixed over time.
  • Web Services should follow the standards of Web.

REST uses Web Verbs to communicate to the services. The verbs like GET, POST, DELETE, PUT are major verbs for REST based applications. If you consider Hi - REST for your application, you should be strict of choosing these Verbs. According to the norms:

  • GET - Used to Retrieve Data
  • POST - To Append Data into the server
  • PUT - Used for Inserts and Updates
  • DELETE - Used to delete data

So each of these verbs produces a complete CRUD (Create, Retrieve, Update, Delete) for a Data centric service and which works the same way as Web works.

Steps to Create REST Based Service

Now let us take a quick pick on how you could build a REST based service. I will use standard CRUD operation for my application and also try to look into it through a Browser.

REST services work the same way. First you need to create a Service with OperationContract and DataContract. The DataContract will have the Complex type if you want to use and the OperationContract will place all the operation on Data. So let's build one normal WCF application.

public interface ICRUDContact
    Contact GetContact(string roll);

    bool SaveContact(Contact currentContact);

    bool RemoveContact(string roll);

    List<Contact> GetAllContacts();

// Use a data contract as illustrated in the sample below 
//to add composite types to service operations
public class Contact
    public int Roll { get; set; }

    public string Name { get; set; }

    public string Address { get; set; }

    public int Age { get; set; }

[ServiceBehavior(InstanceContextMode= InstanceContextMode.Single)]
public class CRUDContact : ICRUDContact
    private List<Contact> _store;
    internal List<Contact> Store
            this._store = this._store ?? new List<Contact>();
            return this._store;

    #region ICRUDContact Members

    public Contact GetContact(string roll)
        return this.Store.FirstOrDefault(item => item.Roll.ToString().Equals(roll));

    public bool SaveContact(Contact currentContact)
        if (this.Store.Any(item => item.Roll == currentContact.Roll))
            return false;
        return true;

    public bool RemoveContact(string roll)
        var currentContacts = this.Store.Where(item => item.Roll.ToString().Equals(roll));

        if (currentContacts.Count() <= 0)
            return false;

        foreach (Contact currentContact in currentContacts)

        return true;

    public List<Contact> GetAllContacts()
        return this.Store;


The code above is very straight forward, where the service exposes four Operations:

  1. GetContact: Retrieves an individual contact from the list
  2. SaveContact: Saves the contact into a list and returns status
  3. RemoveContact: Removes an existing contact and returns status
  4. GetAllContacts: Retrieves all contacts as List

So now if you use BasicHttpBinding for the service and create a servicehost for the application, you could easily consume the service and work on it. Notably I have used:

[ServiceBehavior(InstanceContextMode= InstanceContextMode.Single)]

to ensure that the service will create only one instance of the class and hence every request will work on the same List.

Convert the Application to REST

Now let's see how easily you can convert the application to use REST services. REST needs you to create UriTemplate for each Service Operations. To do this, let's follow the steps:

  1. Add System.ServiceModel.Web.dll. This DLL allows you to produce REST based service. It exposes attributes like WebGet or WebInvoke which lets you to specify the UriTemplate for the current operation and also lets you specify the Method.
  2. Apply WebGet attribute for Get requests and specify complete Uri for the service operation. You could use {0} to specify the parameters to the request. Please make sure the name of the parameter and the name of the variable in the service matches exactly and each of those parameters are of type String.
  3. WebInvoke allows you to specify the Method thorough which the request to be made. Unlike WebGet, WebInvoke allows you to specify Method parameter which could be POST, PUT, DELETE or even GET.

So after changing the contract, my service would look like:

public interface ICRUDContact
    Contact GetContact(string roll);

    [WebInvoke(Method="POST", UriTemplate="contacts")]
    bool SaveContact(Contact currentContact);

    [WebInvoke(Method = "DELETE", UriTemplate = "contact/{roll}")]
    bool RemoveContact(string roll);

    [WebGet(UriTemplate = "contacts")]
    List<Contact> GetAllContacts();

So basically, I have to specify the UriTemplate for each of the service contracts for the existing operations. The first operation GetContact will operate on WebGet which will be mapped into contact/{roll}. So if you call the service contact/1 it will map to the Service contract GetContact with roll 1.

WebInvoke on the other hand allows you to specify Method, as in RemoveContact and SaveContact I have used DELETE and POST methods.

Note: The notion of building UriTemplate is to specify some form of unique URI. Always keep in mind, the external world will request the service using the URI.

Now let's go to our ServiceHost application and configure the service to use REST based approach. Basically for REST based service, you need to use webHttpBinding as Binding configuration.

    <service name="ContactService.CRUDContact" behaviorConfiguration="httpBehaviour">
      <endpoint address="" binding="webHttpBinding"
          <dns value="localhost"/>
      <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange"/>
          <add baseAddress="http://localhost:8080/ContactService/"/>
      <behavior name="httpBehaviour">
        <serviceMetadata httpGetEnabled="True"/>
        <serviceDebug includeExceptionDetailInFaults="False"/>
      <behavior name="httpEndpointBehavour">
        <webHttp />

As you can see, my service now uses WebHttpBinding rather than BasicHttpBinding and also created one EndpointBehaviour to have webHttp for the service configured for my endpoint. You don't need to change anything here.

Now if you run your service host, you will see that the service is running.

To Test the Application

REST services are being called from WebBrowsers, so let's open a web browser and see the list of all contacts.
Let's browse http://localhost:8086/ContactService/contacts,


So it will produce an XML with all ArrayOfContact. Basically REST services communicate using XML. If you want to send a form using POST or PUT, you need to create an XML document with the same schema as specified in the DataMember, the REST service will parse your XML and produce the .NET objects.

Let us call another service method.


Here the URL is called using the Roll 1 which is passed as argument. And hence you receive the XML data as Response from the service containing the Contact Info.


It is fun creating RESTful service. I am still in the learning phase of WCF, so if there are any mistakes, please let me know.

Looking for your feedback.


  • 3rd October, 2010: Initial post


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Abhishek Sur
India India
Did you like his post?

Oh, lets go a bit further to know him better.
Visit his Website : to know more about Abhishek.

Abhishek also authored a book on .NET 4.5 Features and recommends you to read it, you will learn a lot from it.

Basically he is from India, who loves to explore the .NET world. He loves to code and in his leisure you always find him talking about technical stuffs.

Presently he is working in WPF, a new foundation to UI development, but mostly he likes to work on architecture and business classes. ASP.NET is one of his strength as well.
Have any problem? Write to him in his Forum.

You can also mail him directly to

Want a Coder like him for your project?
Drop him a mail to

Visit His Blog

Dotnet Tricks and Tips

Dont forget to vote or share your comments about his Writing

You may also be interested in...

Comments and Discussions

Question[My vote of 1] I agree, no POST client call Pin
msdevtech7-Jun-13 6:12
membermsdevtech7-Jun-13 6:12 
GeneralMy vote of 1 Pin
msdevtech22-Oct-12 9:58
membermsdevtech22-Oct-12 9:58 
GeneralRe: My vote of 1 - POST explained!! Pin
Phani Katakam1-Dec-12 4:55
memberPhani Katakam1-Dec-12 4:55 
QuestionGreat article, 5 for me, got a simple question though Pin
Janilane16-Aug-12 1:48
memberJanilane16-Aug-12 1:48 
QuestionGood Article Pin
Rajeshjoseph14-Aug-12 17:21
memberRajeshjoseph14-Aug-12 17:21 
GeneralExcellent article Pin
Connect2satyam22-Jun-12 1:09
memberConnect2satyam22-Jun-12 1:09 
Questioni don't know how to delete item. Pin
woojja2-Aug-11 4:10
memberwoojja2-Aug-11 4:10 
AnswerRe: i don't know how to delete item. Pin
Abhishek Sur2-Aug-11 10:02
mvpAbhishek Sur2-Aug-11 10:02 
GeneralMy vote of 5 Pin
moldau0429-Oct-10 11:55
membermoldau0429-Oct-10 11:55 
GeneralRe: My vote of 5 Pin
Abhishek Sur6-Nov-10 12:54
mvpAbhishek Sur6-Nov-10 12:54 
Thnx. Wink | ;)
Abhishek Sur
Don't forget to click "Good Answer" if you like this Solution.
Visit My Website-->

GeneralMy vote of 5 Pin
thatraja4-Oct-10 3:33
memberthatraja4-Oct-10 3:33 
GeneralRe: My vote of 5 Pin
Abhishek Sur4-Oct-10 5:05
mvpAbhishek Sur4-Oct-10 5:05 
GeneralMy vote of 5 Pin
KunalChowdhury3-Oct-10 9:09
mentorKunalChowdhury3-Oct-10 9:09 
GeneralRe: My vote of 5 Pin
Abhishek Sur4-Oct-10 5:06
mvpAbhishek Sur4-Oct-10 5:06 
GeneralMy vote of 5 Pin
sashidhar3-Oct-10 8:23
membersashidhar3-Oct-10 8:23 
GeneralRe: My vote of 5 Pin
Abhishek Sur3-Oct-10 8:36
mvpAbhishek Sur3-Oct-10 8:36 
GeneralRe: My vote of 5 Pin
Amol Rawke Pune29-Jan-13 22:59
memberAmol Rawke Pune29-Jan-13 22:59 
GeneralMy vote of 5 Pin
Brij3-Oct-10 7:39
mentorBrij3-Oct-10 7:39 
GeneralRe: My vote of 5 Pin
Abhishek Sur3-Oct-10 8:18
mvpAbhishek Sur3-Oct-10 8:18 
GeneralMy vote of 5 Pin
Abhijit Jana3-Oct-10 7:22
mvpAbhijit Jana3-Oct-10 7:22 
GeneralRe: My vote of 5 Pin
Abhishek Sur3-Oct-10 8:17
mvpAbhishek Sur3-Oct-10 8:17 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web04 | 2.8.151125.3 | Last Updated 3 Oct 2010
Article Copyright 2010 by Abhishek Sur
Everything else Copyright © CodeProject, 1999-2015
Layout: fixed | fluid