Skip to main content

How to create WCF service, Host service in IIS & cosume it in web application

creating, hosting & consuming of wcf service is explained using one small example.
To know how to create, host & consume wcf service follow below steps.
In Visual Studio go to "File" -> "New" -> "Project..." then select "C#" -> "WCF" -> "WCF Service Library".

Now set the name of the project as "ProductServiceLibrary" then click "OK".

WCF1.jpg

In the next step change the name of the files:

From "IService.cs" to "IProductService.cs"
From "Service.cs" to "Product Service.cs"

WCF2.jpg

Now in "IProductService.cs" write the following code to implement it with the Service Class i.e. "ProductService.cs":

using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text;

namespace ProductServiceLibrary
{
    [ServiceContract]
    public interface IProductService
    {
        [OperationContract]
        List<Product> GetAllProduct();

        [OperationContract]
        Product GetProductByID(string ProductId);

    }

   
    [DataContract]
    public class Product
    {
        [DataMember]
        public int ProductID
        {
            get;
            set;
        }

        [DataMember]
        public string ProductName
        {
            get;
            set;
        }

        [DataMember]
        public string QuantityPerUnit
        {
            get;
            set;
        }

        [DataMember]
        public decimal UnitPrice
        {
            get;
            set;
        }
    }
}

After creating the interface we must implement it and must write code for the service.

WCF3.jpg
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text;

namespace ProductServiceLibrary
{
    public class ProductService : IProductService
    {

        public List<Product> GetAllProduct()
        {
            throw new NotImplementedException();
        }

        public Product GetProductByID(string ProductId)
        {
            throw new NotImplementedException();
        }
    }
}

Now we have implemented the IProductService interface with the Service.

We must write the code to get all the products from the database and one product detail by product ID.

But before this we will set the database connection string in the Project property.

WCF4.jpg

WCF5.jpg

WCF6.jpg

After clicking "Ok" open the "App.config" file and we will see the database connection string.

WCF7.jpg

After setting the connection string in the project properties, now we will write code to access the data from the database in the methods we implemented.

So here is the code:
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text;
using System.Data.SqlClient;

namespace ProductServiceLibrary
{
    public class ProductService : IProductService
    {

        public List<Product> GetAllProduct()
        {
            List<Product> Products = new List<Product>();
            using (SqlConnection con = new SqlConnection(Properties.Settings.Default.ConStr))
            {
                using (SqlCommand cmd = new SqlCommand("Select ProductId,ProductName,QuantityPerUnit,UnitPrice from Products", con))
                {
                    con.Open();

                    SqlDataReader dr = cmd.ExecuteReader();
                    while (dr.Read())
                    {
                        Product product = new Product();
                        product.ProductID = dr.GetInt32(0);
                        product.ProductName = dr.GetString(1);
                        product.QuantityPerUnit = dr.GetString(2);
                        product.UnitPrice = dr.GetDecimal(3);

                        Products.Add(product);
                    }

                }
            }
            return Products;
        }

        public Product GetProductByID(string ProductId)
        {
            Product product = new Product();
            using (SqlConnection con = new SqlConnection(Properties.Settings.Default.ConStr))
            {
                using (SqlCommand cmd = new SqlCommand("Select ProductId,ProductName,QuantityPerUnit,UnitPrice from Products", con))
                {
                    con.Open();

                    SqlDataReader dr = cmd.ExecuteReader();
                    while (dr.Read())
                    {
                        product.ProductID = dr.GetInt32(0);
                        product.ProductName = dr.GetString(1);
                        product.QuantityPerUnit = dr.GetString(2);
                        product.UnitPrice = dr.GetDecimal(3);
                       
                    }

                }
            }
            return product;
        }
    }
}

Now our first WCF has been created. It is time to test our WCF Service Application; just press the F5 button.

The WCF Test Client will run.

WCF8.jpg

Select the method "GetAllProduct" and click "Invoke".

WCF9.jpg

The preceding screen is the indication that the f WCF Service was created successfully.

Now our second step is just to host this WCF Application using IIS.

Click on the solution then right-click then select "Add" -> "New Website".

WCF10.jpg

WCF11.jpg

After clicking "OK" the Website application will be added to the solution. Then after it has been added it, two extra files will get generated in the project, i.e. "IService.cs" & "Service.cs". We have, however, already created these file in the WCF Library, so now we will delete them and add the reference to "ProductServiceLibrary.dll".

WCF12.jpg

Add the reference to the ProductServiceLibrary.dll in this project.

WCF13.jpg

WCF14.jpg

WCF15.jpg

Now open the Service.svc file.

Delete the selected code (in the following image) and the reason is very simple, because in our ProductServiceLibrary.dll we created the ProductService.cs and in the current project we have deleted the Service.cs file from the App_code folder.

And replace the current line with this line of code:
 
<%@ ServiceHost Language="C#" Debug="true" Service="ProductServiceLibrary.ProductService" %>
WCF16.jpg

We have altered the .svc file and it is time to add the End Points to Web.Config, as in:
 
<?xml version="1.0"?>
<configuration>

  <system.web>
    <compilation debug="false" targetFramework="4.0" />
  </system.web>
  <system.serviceModel>
    <services>
      <service name="ProductServiceLibrary.ProductService">
        <endpoint address="" binding="wsHttpBinding" contract="ProductServiceLibrary.IProductService">
          <identity>
            <dns value="localhost" />
          </identity>
        </endpoint>
        <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
       
      </service>
    </services>
   
    <behaviors>
      <serviceBehaviors>
        <behavior>
          <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before deployment -->
          <serviceMetadata httpGetEnabled="true"/>
          <!-- To receive exception details in faults for debugging purposes, set the value below to true.  Set to false before deployment to avoid disclosing exception information -->
          <serviceDebug includeExceptionDetailInFaults="false"/>
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
  </system.serviceModel>
  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>

</configuration>

After adding the End Points in the web.config file, our hosting task is finished. Now it is time to test the Hosting Application.

For that please use the following steps in the following image:

WCF17.jpg

WCF18.jpg

WCF19.jpg

The preceding color full page is the indication of successfully hosting WCF in IIS.

Now our next step is to consume this WCF IIS hosted service in a client application and this is a very easy task.

So let's proceed to our last step.

WCF20.jpg


WCF21.jpg

WCF22.jpg


WCF23.jpg

WCF24.jpg

WCF25.jpg

WCF26.jpg
On the Default.aspx.cs page write the code:
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using ProductWebClient.ProductServiceClient;
namespace ProductWebClient
{
    public partial class Default : System.Web.UI.Page
    {

        protected void Page_Load(object sender, EventArgs e)
        {

        }

        protected void BtnAdd_Click(object sender, EventArgs e)
        {
            ProductServiceClient.ProductServiceClient proxy = new ProductServiceClient.ProductServiceClient();
            ProductGridView.DataSource= proxy.GetAllProduct();
            ProductGridView.DataBind();


        }
    }
}

Now run the application, except before doing that do one more last task.

WCF27.jpg

WCF28.jpg

Set the ProductWebClient as "Set as StartUp Project" and press F5 and here is the result.

Popular posts from this blog

Creating package in Oracle Database using Toad For Oracle

What are Packages in Oracle Database A package is  a group   of procedures, functions,  variables   and  SQL statements   created as a single unit. It is used to store together related objects. A package has two parts, Package  Specification  and Package Body.

Resolving 'Setup Account Privileges' error while installing SQL Server

A new installation of Microsoft SQL Server 2012 or Microsoft SQL Server 2008 R2 fails You see the following error message when you try to install a new instance of SQL Server 2012 or SQL Server 2008 R2: Rule "Setup account privileges" failed.

Creating Oracle stored Procedures using TOAD for Oracle

In a database management system, a  stored procedure  is a set of Structured Query Language (SQL) statements with an assigned name that's stored in the database in compiled form so that it can be shared by a number of programs. The use of  stored procedures  can be helpful in controlling  access to data, preserving  data integrity  and  improving  productivity.