象 asp、asp.net 等诸多基于 web 的应用程序的安装与部署一直是个麻烦事情,一般都是手工复制、手工修改相关配置文件(主要是数据库配置),和 windows 上 installer 或 linux 上的 rpm 相比,这种方式显然一点技术含量都没有。
对于胖客户端应用,从很早开始就一直都有较为完善的安装程序制作工具了,如 installshield、installanywhere、wise installer、swift installer 等等,其中一部分已经实现了跨平台,可以运行在 windows、linxu、java 等平台上。
从 visual studio 6.0 开始,microsoft 提供了单独的 setup tools ,可以用来制作简易的安装程序,后来,这个工具被集成到 vs.net 2002/2003 中,并且功能做了一些增强,可以制作自定义的对话框等。其优点是能很好的和 vs.net 的项目进行集成,这样在整个解决方案(solution)在 build 的时候,就可以生成安装包,这样便于实现每日构建(daily build),同时其缺点仍然存在,不能对安装过程进行更多地控制,提供的对话框功能和类型有限,很少看到有人利用这些对话框实现对系统的一些较为复杂的配置,如绝大多数应用程序中都会涉及的数据库创建、初始数据的生成等工作。
有很多不错的安装工具中,在安装的过程中就可以对实现对系统进行一些配置,但安装结束后,如果配置发生改变,例如数据库迁移等,又变成一件令人头疼的事情,如果对系统了解较多,知道配置数据的存放位置,就可以手动修改,如果不了解怎么办?难道要先卸载,再重新安装来完成新配置?
在很多不错的胖客户应用中,配置界面是和安装界面独立的,这样便于在安装系统后,灵活地调整其配置,那么就把它拿到 asp.net 的安装程序中吧。
1) 建立解决方案 solution。
2) 建立 web 应用 。
3) 新增一个 winforms 应用 appconfig,增加一个 winform ,完成初始化系统环境,修改系统配置的功能(如生成数据库、生成初始数据、修改 web.config 中的数据库连接参数,machine.config 或自定义配置文件)等功能,生成 appconfig.exe 。
4) 新增一安装项目 setup,除了将 web 应用的的“主输出”和“内容输出”加入到项目中,还要将 appconfig 的“主输出”加入到此项目中。
5) 在 setup 项目中的“自定义操作中”的“安装”节,增加一自定义操作,使其运行来自于 appconfig 的“主输出” appconfig.exe。
这样 asp.net 的安装程序在运行的最后阶段,会运行 appconfig 的 winform 程序,来完成相关的配置,如数据库等。如果以后配置发生改变,可以直接运行 appconfig.exe 来更改配置。
值得一提的是,由于 appconfig 是 winforms 应用,相对于 installer 的对话框而言,有很大的发挥余地,例如我经常在项目中加入 sql server 管理对象 interop.sqldmo.dll 的引用,这样可以在输入/选择 sql server 的列表框中实现自动列出可用的 sql server 名称列表,看起来很专业的样子。
新闻热点
疑难解答
图片精选