ClickOnce Deployment : System.Deployment API

ClickOnce is the deployment revolution for SmartClient applications. This is very cost effective solution for Smart Client applications. Support cost is very less and the deployment is per user basis. So user does not need Administrator right to install the application and security sandboxing is integral part to it. Automatic update notification can be implemented easily. One server is enough for n number of user installation. We can enjoy the power of windows application at the cost of Web Application.

 

The automatic update has one problem in it. If you skip the update notification next time it won’t popup the notification for you. That means if the update is critical you may need to uninstall the application and the install form the server location. Also if you rollback the installation (can be done from Add/Remove Program) you won’t get the notification for latest update. But it can be solved by ClickOnce version number. That means you can tell your smart client application that user need to have minimum version at their machine to run.

 

That’s why the extensibility comes into the picture. We need to give option for the end user that they can download and install the application on demand. In wizard we cannot do much of it but we have System.Deployment API for it. This API helps us to write our own code especially for on demand installations.

 

The below example shows how to do it, (I have added a button in my code to run the on demand installation, you can add this functionality to your application’s menu). You need to implement the namespace System.Deployment.Application.

 

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Deployment.Application;

 

namespace ClickOnce_MSDN

{

    
public partial class Form1 : Form

    
{

        
public Form1()

        
{

            InitializeComponent();

        }


 

        ApplicationDeployment ad;

        
private void cbUpdate_Click(object sender, EventArgs e)

        
{

            ad 
= ApplicationDeployment.CurrentDeployment;

 

            ad.CheckForUpdateCompleted 
+= new         

              CheckForUpdateCompletedEventHandler(ad_CheckForUpdateCompleted);

 

            
//Event to show the progressbar

            ad.UpdateProgressChanged 
+= new           

              DeploymentProgressChangedEventHandler(ad_UpdateProgressChanged);

 

            
//Event to restart the application,

            
//otherwise changes will not reflect

            ad.UpdateCompleted 
+= new

               AsyncCompletedEventHandler ad_UpdateCompleted);

 

            
//Call the method to invoke the update process

            ad.CheckForUpdateAsync();

        }


 

        
void ad_UpdateCompleted(object sender, AsyncCompletedEventArgs e)

        
{

            Application.Restart();

        }


 

        
//to show the progressbar

        
void ad_UpdateProgressChanged(object sender,                

              DeploymentProgressChangedEventArgs e)

        
{

            
this.progressBar1.Value = e.ProgressPercentage;

        }


 

        
void ad_CheckForUpdateCompleted(object sender,

            CheckForUpdateCompletedEventArgs e)

        
{

            
if (e.UpdateAvailable)

            
{

                
//Async UPDATE

                ad.UpdateAsync();

            }


        }


    }


}
 
發佈了3 篇原創文章 · 獲贊 0 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章