Click here to Skip to main content
15,867,488 members
Articles / Web Development / ASP.NET

CREATE RESTful WCF Service API Using POST: Step By Step Guide

Rate me:
Please Sign up or sign in to vote.
4.71/5 (49 votes)
25 May 2011CPOL4 min read 452.4K   17.2K   100   61
This article will help you to create RESTful WCF POST API. I have given Client and Server example which is really easy to understand.

Introduction

In my previous article, I tried to explain about WCF Restful service using HTTP Get method. This works well as long as you are sending small data as information to the service. But if want to deliver huge data, HTTP GET Method is not a good choice. In this article, we will create one WCF RESTFul POST API. I will also try to explain why and where to use POST method.

Why to use POST, not GET?

When I write any WCF service, I always use POST. The reason is the advantage of POST over GET. Using HTTP POST method, you can almost achieve everything which you can achieve from GET. Despite this, you will get some additional feature if using POST. We might say that "GET" is basically for just getting (retrieving) data whereas "POST" may involve anything, like storing or updating data, or ordering a product, or sending E-mail, etc.

POST

  1. Easy Character Encoding using application/x-www-form-urlencoded
  2. No Proxy by default so always actual data from web server
  3. Data length can be restricted by webserver, not by browser

GET

  1. Character encoding will reduce the amount of data that can be used because of URL encoding entities (i.e. three Japanese characters are converted to this: %26%2312454%3B%26%2312455%3B%26%2312502%3B)
  2. Running an HTTP request with GET can be cached on your web browser or a configured proxy server
  3. Maximum URL length is 2,083 characters in Internet Explorer (see MaxClientRequestBuffer: Use POST instead of GET to send large amounts of data in request)

and lot more...

Extremely long URLs are usually a mistake. URLs over 2,000 characters will not work in the most popular web browser. Sending long information via URL is not a good way of implementation and also it has many restrictions, i.e., max length of URL, information format, bla bla bla. For example, Internet Explorer has a limitation implemented at 2083 characters. URI is meant to be readable not to send information.

So if you are writing any REST service and your information is long enough, better to choose POST instead of GET method.

In this article, I am going to create WCF Restful service using POST method and access it using HTTP Request. So we will have client and server both in this example code. I am creating one service which accepts HTTP Post XML request and response request data in XML format.

Step by Step Guide

STEP 1

Launch Visual Studio 2010. Click FILE->NEW->PROJECT. Create new "WCF Service Application".

Image 1

STEP 2

Once you create the project, you can see in solution that by default WCF service and interface file are already created. Delete by default created file as we will create our own interface and WCF service file.

Step-2

STEP 3

Now right click on solution and create one new WCF service file. I have given name to the service file as “RestServiceImpl.svc”.

Image 3

STEP 4

We will create two DataContract classes for request and response purposes.

Step-4

RequestData will receive the request from the client and ResponseData response. One very important thing is that POST XML format to the service should be the same as RequestData. So the post XML request format can be like below:

Step-4

We must have to use namespace for the data contract in POST RESTFul service, which has multiple uses, i.e., reflects the current version of your code. The same namespace should use in XML to Post data. Here, I have given http://www.eysnap.com/mPlayer as namespace which can be changed.

STEP 5

Now we will write the OperationContract in IRestServiceImpl which is an interface. Below is the code for that.

Image 6

As we can see in the above code, here Request and Response format is XML. We can change it to JSON also by changing the WebMessageFormat <span></span>from WebMessageFormat.Xml to WebMessageFormat.Json.

STEP 6

Implementation of Auth OperationContract in RestServiceImpl.svc.cs here.

STEP-6

STEP 7

Now let’s move to the configuration part which is the last one. There will be two basic parts of the configurations file which we must have to understand.

Services

Image 8

Behaviors

Image 9

And that’s it. Our Restful WCF POST RESTful service is ready to test.

SERVICE IS READY

I have created one Test WebClient in C# which makes HTTP request with some XML data. My application is hosted on localhost and URL is http://localhost:35798/RestServiceImpl.svc/auth. I launched and invoked service using WebClient. Below is my XML response which is the correct one.

Image 10

This service can be used by any language application (.NET, PHP, JAVA, etc.) and that is the major reason to use REST service in the application.

Hope the article is useful for the community. Comments, suggestions and criticisms are all welcome.
Thanks.

History

  • 25th May, 2011: Initial post

License

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


Written By
Software Developer (Senior) http://mr-ashu.blogspot.com/
Singapore Singapore
A versatile person having 10 Years of IT Industry experience in software development on .NET and Android Technology.

Comments and Discussions

 
AnswerRe: not working Pin
ashutosh k. shukla19-Apr-12 5:59
ashutosh k. shukla19-Apr-12 5:59 
QuestionAshutosh need your help soon Pin
Member 884729719-Apr-12 5:35
Member 884729719-Apr-12 5:35 
AnswerRe: Ashutosh need your help soon Pin
ashutosh k. shukla19-Apr-12 6:01
ashutosh k. shukla19-Apr-12 6:01 
GeneralRe: Ashutosh need your help soon Pin
Member 884729719-Apr-12 6:17
Member 884729719-Apr-12 6:17 
GeneralRe: Ashutosh need your help soon Pin
Member 884729719-Apr-12 6:20
Member 884729719-Apr-12 6:20 
QuestionAgain I need your Help Please (its urgent for me) Pin
MaheshRastogi00513-Feb-12 3:40
MaheshRastogi00513-Feb-12 3:40 
Questionparameter in url with out question mark Pin
MaheshRastogi00512-Feb-12 2:57
MaheshRastogi00512-Feb-12 2:57 
QuestionIs there a way to test a post directly from the URL of a browser? Pin
littleGreenDude3-Feb-12 9:58
littleGreenDude3-Feb-12 9:58 
Is there a way to test a post directly from the URL of a browser?

What is the syntax of the line that can be typed in to the URL of a browser to test the post method described in your example?
AnswerRe: Is there a way to test a post directly from the URL of a browser? Pin
ashutosh k. shukla3-Feb-12 17:39
ashutosh k. shukla3-Feb-12 17:39 
SuggestionRe: Is there a way to test a post directly from the URL of a browser? Pin
ps3645210-Feb-12 0:15
ps3645210-Feb-12 0:15 
GeneralRe: Is there a way to test a post directly from the URL of a browser? Pin
ashutosh k. shukla10-Feb-12 0:17
ashutosh k. shukla10-Feb-12 0:17 
Questionplease help me its urgent Pin
MaheshRastogi0051-Feb-12 4:21
MaheshRastogi0051-Feb-12 4:21 
AnswerRe: please help me its urgent Pin
ashutosh k. shukla1-Feb-12 4:24
ashutosh k. shukla1-Feb-12 4:24 
GeneralRe: please help me its urgent Pin
MaheshRastogi0051-Feb-12 4:28
MaheshRastogi0051-Feb-12 4:28 
GeneralRe: please help me its urgent Pin
ashutosh k. shukla1-Feb-12 4:28
ashutosh k. shukla1-Feb-12 4:28 
QuestionCan I consume REST WCF via iPhone web app. Pin
kartikps_19795-Dec-11 10:54
kartikps_19795-Dec-11 10:54 
AnswerRe: Can I consume REST WCF via iPhone web app. Pin
ashutosh k. shukla5-Dec-11 16:17
ashutosh k. shukla5-Dec-11 16:17 
QuestionGreat example Pin
Naresh Mittal16-Nov-11 17:14
Naresh Mittal16-Nov-11 17:14 
AnswerRe: Great example Pin
ashutosh k. shukla17-Nov-11 7:59
ashutosh k. shukla17-Nov-11 7:59 
Questioncan RequestData have more than one data contract? Pin
Selveia15-Nov-11 4:27
Selveia15-Nov-11 4:27 
AnswerRe: can RequestData have more than one data contract? Pin
Naresh Mittal16-Nov-11 17:18
Naresh Mittal16-Nov-11 17:18 
QuestionThe remote server returned an error: (405) Method Not Allowed. Pin
Selveia13-Nov-11 9:53
Selveia13-Nov-11 9:53 
AnswerRe: The remote server returned an error: (405) Method Not Allowed. Pin
ashutosh k. shukla13-Nov-11 15:50
ashutosh k. shukla13-Nov-11 15:50 
GeneralRe: The remote server returned an error: (405) Method Not Allowed. Pin
Selveia13-Nov-11 23:19
Selveia13-Nov-11 23:19 
QuestionThanks and keep it up Pin
Rupesh Kumar Tiwari20-Oct-11 5:38
Rupesh Kumar Tiwari20-Oct-11 5:38 

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.