Click here to Skip to main content
13,401,968 members (48,306 online)
Click here to Skip to main content
Add your own
alternative version


28 bookmarked
Posted 6 Aug 2008

Web Form with Progress Bar of Web Service Execution

, 6 Aug 2008
Rate this:
Please Sign up or sign in to vote.
Show developers how to manage state of long running web service and then use this state in Ajax enabled web form


The purpose of this article is to show how to get progress notifications of current web service progress. This will be achieved by using AJAX enabled web page, async call to web service and some easy CSS trick to display progress bar. This article also shows how to manage state of web service.

  1. Look at the web service code. To manage state of a web service, we use a class named ProgressValues and Cache object. Values are stored in Cache with unique ID.

    public class ProgressValues
        public bool AbortPressed = false;
        public int step = 0;
        public int value = 0;
    ProgressValues pw = new ProgressValues();
    Context.Cache[UID] = pw;
  2. Web page has an AJAX Timer which is disabled by default and starts tick when user presses the start button and also has AJAX UpdatePanel to display progress bar, controls and GridView without full page postbacks.

  3. When user clicks "Start Process" button we make async execution of a web service and pass values of IAsyncResult to Session object by the following lines of code:

    MyService.Test ts = new MyService.Test();
    // AsyncResult for async execution of service
    IAsyncResult my_ar;         
    // Start async execution of web service
    my_ar = ts.BeginGo(UID, steps, values, null, null); 
    // Remember AsyncResult in Session for later use
    Session["my_ar"] = my_ar;
  4. When tick event occurs, we get IAsyncResult from Session and update controls with the following lines of code:

    // Get IAsyncResult from Session
    IAsyncResult my_ar = (IAsyncResult)Session["my_ar"]; 
    // Get ProgressValues from web service
    pw = ts.GetProcessValues(Session["WebServiceUID"].ToString()); 
    // Async execution of service done
    if (my_ar.IsCompleted)  

Using the Code

First of all, you need Microsoft AJAX installed on your web server. Second, you need to compile/deploy/start TestService project into your web server, then add Web References to "Test project" with name MyService. If you do this, then Proxy class for your service will exist and you can use this proxy class in Test project.


  • 6th August, 2008: Initial post


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


About the Author

Russian Federation Russian Federation
No Biography provided

You may also be interested in...


Comments and Discussions

GeneralMy vote of 5 Pin
Member 109855831-Aug-14 4:22
memberMember 109855831-Aug-14 4:22 
QuestionWeb object created every time that the timer is called? Pin
LEM320-Jul-10 13:38
memberLEM320-Jul-10 13: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.

Permalink | Advertise | Privacy | Terms of Use | Mobile
Web02 | 2.8.180218.2 | Last Updated 6 Aug 2008
Article Copyright 2008 by Forkossigan
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid