Click here to Skip to main content
6,594,432 members and growing! (15,699 online)
Email Password   helpLost your password?
Platforms, Frameworks & Libraries » Windows Communication Foundation » General     Advanced License: The Code Project Open License (CPOL)

Integrating WCF Services

By taufufah

This article describes how WCF services can be loaded on-the-fly (without prior knowledge of the services’ contracts), setting its parameters and sequencing their invocation.
C# (C# 3.0), Windows, Win32, Visual Studio (VS2005), WCF, WinForms, Architect, Dev, Design
Posted:24 Apr 2008
Views:12,159
Bookmarked:33 times
Unedited contribution
Announcements
Loading...
 
Search    
Advanced Search
Add to IE Search
printPrint   add Share
      Discuss Discuss   Broken Article?Report  
11 votes for this article.
Popularity: 4.93 Rating: 4.74 out of 5

1

2
1 vote, 9.1%
3
2 votes, 18.2%
4
8 votes, 72.7%
5

Introduction

The basic concept that this article is trying to present is how to subscribe to WCF services on-the-fly without prior knowledge of the services’ contract definitions. Once these services are loaded, user could then select desired operations from these services to be invoked sequentially through a simple sequencer. User could also set value for any parameters of a certain operation. With such concept, services located independently at different locations could be integrated to form a larger scale solution.

Please note that this article is just trying to illustrate a basic possibility of working with WCF services. Many more advanced possibilities are omitted from the article and are suggested in Todo section below.

Credits

The sample project made references to the following great works:

Dynamic Programming with WCF by Vipul ModiA General Fast Method Invoker by Luyan

Using the code

The concept is really pretty simple. There are services hosted somewhere ready to be subscribed. These are just ordinary WCF services. The client application can load these services by requiring user to key in the desired service’s URL. For the sample project, a service called ExampleService is hosted at the following URL.

http://localhost:8080/WcfSamples/DynamicProxy

public class ExampleService : IWorkWithIntrinsic
{
    #region IWorkWithIntrinsic Members

    public void WorkWithIntegers(int first, int second)
    {
        Console.WriteLine("IWorkWithIntrinsic.WorkWithIntegers was called.");
        Console.WriteLine("\t1st Integer: " + first);
        Console.WriteLine("\t2nd Integer: " + second);
    }

    public string WorkWithString(string myString)
    {
        Console.WriteLine("IWorkWithIntrinsic.WorkWithString was called.");
        Console.WriteLine("\tString: " + myString);
        return myString + " returned from server.";
    }

    public double WorkWithDouble(double myDouble)
    {
        Console.WriteLine("IWorkWithIntrinsic.WorkWithDouble was called.");
        Console.WriteLine("\tDouble: " + myDouble);
        return myDouble + 1.0;
    }

    #endregion
}
           

User could load (subscribe) a service by going for File, Load Service. The following dialog box will greet the user. User should check the Load All Contracts check box and click Ok.

loadservice.JPG

All loaded services (proxies) will appear in a tree view. User can then choose desired operations to be added to the sequencer by performing a right click on the operation node and choose Add Operation. This is shown in the following diagram.

addoperations.JPG

Finally, user can click on the Play button to execute all selected operations.

integrator.JPG


The following screen shot depicts the sequence of events that have taken place on the server side.

server.JPG

Brief Description of Each Projects in the Solution

Integrator.Framework.DynamicProxyModel – A project that made dynamic proxy creation possible. Almost everything here are taken from the great works by Vipul Modi as described above.

Integrator.Framework.ServiceManagerModel – A project that manages all loaded proxies and its operations and parameters.

Integrator.Framework.Sequencer – Consists of the sequencer component.

Integrator.Framework.TestServer – Service Host Application.

Integrator.UI.Shell – CAB Shell that host all UI components.

Integrator.UI.Sequencer – UI that host the sequencer.

Integrator.UI.LoadedServices – UI that host all loaded proxies.

Integrator.UI.ParameterEditor – UI that host the parameter editor.

Integrator.UI.Common – Consists of constants and event arguments for all UI components.

Running the Sample Projects

Set Integrator.Framework.TestServer as active project and execute it by pressing Alt-F5 from Visual Studio 2005.

Set Integrator.UI.Shell as active project and execute the project by pressing F5 from Visual Studio 2005. Perform the steps as described in Description on Basic Concept section above.

Todo

The following items are planned features for the project that I can’t find time to get them implemented.

Event Broker System – to work with the sequencer in order to construct a Publish\Subscribe model. The idea is, once an operation is completed, its return parameter can be used as input parameter to another operation.

Handling complex parameters - currently, code to handle complex parameter have been included but only half-baked.

Serving UI - Having the service to serve its own UI (possibly XAML).

License

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

About the Author

taufufah


Member
Yes, I design. Then, I code. Next, I refactor.
Occupation: Software Developer (Senior)
Location: Malaysia Malaysia

Other popular Windows Communication Foundation articles:

Article Top
You must Sign In to use this message board.
FAQ FAQ 
 
Noise Tolerance  Layout  Per page   
 Msgs 1 to 2 of 2 (Total in Forum: 2) (Refresh)FirstPrevNext
GeneralSupport for .NET 3.5 and ISB PinmemberChristian Weyer5:29 25 Apr '08  
GeneralRe: Support for .NET 3.5 and ISB Pinmembertaufufah6:03 26 Apr '08  

General General    News News    Question Question    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

PermaLink | Privacy | Terms of Use
Last Updated: 24 Apr 2008
Editor:
Copyright 2008 by taufufah
Everything else Copyright © CodeProject, 1999-2009
Web18 | Advertise on the Code Project