clickonce是微软在.NET 2.0框架中发布的一项技术,允许大家在Visual Studio中方便地部署和更新.NET的Windows应用程序。部署功能是通过把应用程序文件复制到一个文件夹中、FTP目录中或者某个Web位置上,并同时附加一个清单文件来实现的。清单文件是一个具有.application扩展名的XML文件,它包含了所有程序文件的一个列表,以及类似发布者标识这样的安全相关信息。clickonce应用程序每发布一个新的版本,一个新的子目录就被创建,并把更新的文件放在这个目录中。程序的所有部署版本都是相互独立存在的,这意味着我们只需要识别用户,并把用户导向应用程序适合的版本,从而控制它们需要接受那个版本的程序。
首先,让我们来创建一个简单的Windows应用程序,并通过clickonce来部署它。创建一个新的Windows应用程序项目,放置一个标签控件到窗体上,并在New()过程中编写一些代码,以便让我们能看到我们拥有的是哪个版本。
label1.Text= "Version: "&_
System.Reflection.Assembly.GetExecutingAssembly.GetName.Version.ToString
现在,打开项目属性界面并浏览签名(Signing)标签页,勾选“Sign the clickonce manifest”复选框,并通过点击“Create Test Certificate”按钮及输入密码来创建一个测试证书。
现在,我们已经拥有证书了,因而可以设置clickonce部署了。选择发布(Publish)标签页,输入发布位置即安装URL(你也可以使用底部的发布向导(Publish Wizard)来直接输入这些)。发布位置是将要存放部署文件的物理位置。安装URL是用户用于下载和安装应用程序的URL。我们打算让这个应用程序能够脱机运行,所以选择在“Install Mode and Settings”之下的第二个单选框。为了实现我们控制版本的功能,我们需要把程序文件部署到一个Web应用程序的文件夹树中,在选择部署位置时务必注意这一点。
注意,更新选项要通过点击“Updates...”按钮来显示。
至此,我们已经具有了一个可以进行部署的clickonce应用程序了。一旦部署并安装好,利用显示出来的更新选项设置,应用程序将会在每次启动的时候检查更新。
如果有新版本存在,那么用户将被提示进行更新。
此时,我们已经部署好一个clickonce应用程序了,接下来可以准备实现版本控制。进行版本细化控制的原理是为主文件.application设置一个基于Web的转向功能.首先,我们要把.application扩展名添加到ISS的允许文件列表中。这可以通过IIS里的Web站点属性,设置界面中的Home Directory标签页上的Application Configuration配置节来实现。
一旦完成这步工作,就可以创建一个新的WebApplication并添加一个Handler类到其中。
接着,在应用程序的web.config文件中注册这个Handler。Handler类型的格式是[Namespace].[ClassName], [Assembly]
<httpHandlers>
<addverb="GET"path="*.application"type="WebApplication1.MyHandler,WebApplication1"/>
httpHandlers>
system.web>
configuration>
现在,返回到我们的示例clickonce应用程序,重新打开Publish标签页下的Updates对话框。输入指向这个Web应用程序的更新位置。
最后,编辑我们之前创建的HttpHandler,让其针对请求返回适合的版本。这里,我们返回一个硬编码的版本,不过一个真实的实现应该处理验证等功能,以提供更好的灵活性。
标头可以在IIS中进行配置或如这里所示的在代码中设置。
一些注意事项
在为clickonce签名使用临时证书时,一旦证书过期,就需要使用一个新的来代替,那么,应用程序的当前安装就不能再升级了,所有用户都必须重新安装应用程序。这是一个已知的缺陷。幸运的是,已经有一种方式能够无限地延长证书的过期时间。访问这个地址来获取详细信息:http://support.microsoft.com/Default.aspx?kbid=925521。
使用更新位置来同步部署应用程序清单的位置非常重要。IIS不能处理未在列表中的文件,所以如果更新路径无效的话你的处理器将永远不会触发。
如果使用Visual Studio 2008,部署文件夹略有不同。每个版本的.application文件都放在他们特定的子目录中,而非在主文件夹中。如果你有一个在VS 2005下设计的版本方案,并在VS 2008中来部署应用程序的话,这就会引起问题。