rainbowzc

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: :: :: 管理 ::
最近在用vs2008开发一个小项目,在安装vs2008时也就意味着同时安装了.net framework 3.5。当前程序里所有的类库目标框架都是.net framework 3.0,(Framework3.5 太大了)。所有关于3.5的引用全删掉了. 打包,在自己机器上测试了下,没有问题, 就匆匆发到测试组。结果:

 

2008-07-28_14-21-41 

当时就傻了,原来测试组的环境都是3.0,但是目标框架都是.net framework 3.0了,怎么还依赖3.5呢?!仔细检查了所有的引用,确定没有用到3.5的dll......莫非是安装程序需要3.5?

仔细检查了安装工程下的各个属性,终于找到问题根源。。。 

2008-07-28_14-12-50

 

2008-07-28_14-11-11

原来 2008安装程序 默认的启动条件是.net framework 3.5。。。。。

特记录此问题,希望能给遇到类似问题的朋友提供借鉴。。

 

 

 

//

用VS2008安装和部署项目

2008年07月01日 星期二 16:57

1、建立安装项目

 

2、添加项目输出

只选择主输出和内容文件

3、设置属性

 

选择一下 必备组件,必备组件的安装位置 选中”从与我的应用程序相同的位置下载系统必备组件“,这样系统会自动把组件复制到安装程序目录的下面,如图示

 

//

VS.NET安装部署深入研究

信很多人都做过安装程序,目前最大功能最全的当属InstallShield,但是InstallShield的语法学习起来实在费劲,相对而言vs.net自带的安装部署短小精悍,且使用C#语法,对于一般C#开发者来说使用起来就极为简便,在对其作了一些研究之后,发现vs.net的安装部署项目的功能也已经非常好用,一般的程序安装都可以轻松实现,当然,在研究的过程中也发现了一些缺陷,这个后面再提。下面就向大家介绍一下ASP.NET安装部署项目的一些复杂应用实现: 首先我们假设存在一个已经完工的web项目eHRM,其文件列表如图
单击显示全图,Ctrl+滚轮缩放图片

其中web.config中存在我们的数据库连接及系统的一些其他配置,如数据库类型等,这些配置需要在安装时进行修改。

OK,知道了我们的安装对象,现在开始做安装部署程序,首先,在解决方案中添加一个新项目,如图,项目类型为Web安装项目,项目名称eHRMSetUp。
单击显示全图,Ctrl+滚轮缩放图片

项目添加完毕,选中eHRMSetUp,会发现工具栏发生了一些变化,如图所示:
单击显示全图,Ctrl+滚轮缩放图片

主要有6个工具按钮,分别代码安装部署的6大编辑器:

1、单击显示全图,Ctrl+滚轮缩放图片表示文件系统编辑器,主要用于目标机器的文件安装操作。 
2、单击显示全图,Ctrl+滚轮缩放图片表示注册表编辑器,用于目标机器的注册表操作。 
3、单击显示全图,Ctrl+滚轮缩放图片表示文件类型编辑器,用于向目标机器安装新的文件类型。 
4、单击显示全图,Ctrl+滚轮缩放图片用户界面编辑器,用于确定安装过程中所用到的一些界面。 
5、单击显示全图,Ctrl+滚轮缩放图片自定义操作编辑器,调用用户自定义的操作代码。 
6、单击显示全图,Ctrl+滚轮缩放图片启动条件编辑器,用于设置安装程序的启动条件。

这6个编辑器不一定全部会用到,我们的demo安装就只需要用到1/4/5大部分的安装包属性均存在于eHRMSetUp项目的属性中,属性界面如图:
单击显示全图,Ctrl+滚轮缩放图片

在这里可以设置产品名称(eHRMSetUp),产品编号(ProductCode)以及安装包全球化类型(Localization)等相关的安装程序属性。除了eHRMSetUp安装部署项目,我们还需要添加一个eHRMSetUpCompenent项目,用来自定义安装操作,在eHRMSetUpCompenent项目中添加一个新的安装程序类,如图:

单击显示全图,Ctrl+滚轮缩放图片

名称为eHRMInstaller.cs,在其中添加如下代码:

复制  保存
protected override void OnAfterInstall(IDictionary savedState)
{
base.OnAfterInstall(savedState);
}
public override void Install(IDictionary stateSaver)
{
base.Install(stateSaver);
}
protected override void OnBeforeInstall(IDictionary savedState)
{
base.OnBeforeInstall(savedState);
}
public override void Uninstall(IDictionary savedState)
{
base.Uninstall(savedState);
}
public override void Rollback(IDictionary savedState)
{
base.Rollback(savedState);
}


这些代码将主要负责对于安装中的操作进行自定义处理,包括建数据库,配置web.config等。为了在安装部署中调用项目eHRMSetUpCompenent定义的操作,需要在项目eHRMSetUp中添加eHRMSetUpCompenent的主输出和项目eHRM的内容输出,具体操作是选择eHRMSetUp项目后右键 —— 添加 —— 项目输出 ——选择项目eHRMSetUpCompenent的主输出,添加完毕后如图:

单击显示全图,Ctrl+滚轮缩放图片

现在回到项目eHRMSetUp,打开文件系统编辑器,点击Web应用程序文件夹,编辑其属性,属性界面如下:
单击显示全图,Ctrl+滚轮缩放图片

其中比较重要的就是VirtualDirectory属性,表示安装后建立的虚拟目录名称,其他属性视具体情况而定。下面通过用户界面编辑器来配置用户的安装界面,vs.net2003目前所提供的窗口比较少,如图:
单击显示全图,Ctrl+滚轮缩放图片

基本是几个比较简单的配置窗口,所以如果需要用到一些复杂的配置,那么这些窗口就远远不够用了,不过我们可以进行部分的扩展来实现这些复杂的配置,具体方法如下: 

1、在项目eHRMSetUpCompenent中添加一个windows窗口FrmConfig.cs,设计我们需要用的界面。 
2、修改eHRMInstaller.cs中的代码如下:

复制  保存
protected override void OnAfterInstall(IDictionary savedState)
{
FrmConfig _FC = new FrmConfig();
_FC.ShowDialog();
base.OnAfterInstall(savedState);
}


3、这样,在安装的过程中会中断并弹出FrmConfig让用户进行配置。最后就是通过自定义操作编辑器来设置安装过程中的自定义操作,从web应用程序文件夹选择主输出来自eHRMSetUpCompenent(活动),添加完毕如图所示:

单击显示全图,Ctrl+滚轮缩放图片

分别设置4个主输出的CustomActionData属性为: /LogicDir=[TARGETDIR] /VitualDir=[TARGETVDIR][TARGETDIR]和[TARGETVDIR]是系统部署自带属性,分别表示安装物理目录地址和虚拟目录地址。设置完这些自定义操作的传入参数后就可以直接在eHRMSetUpCompenent项目的代码中进行调用,调用代码如下:

复制  保存
public override void Install(IDictionary stateSaver)
{
//安装物理目录
    string LogicDir = Context.Parameters["LogicDir"];
//安装虚拟目录
    string VitualDir = Context.Parameters["VitualDir"];
//根据配置安装操作
    base.Install(stateSaver);
}


最后需要做的就是卸载时的一些文件处理:

复制  保存
public override void Uninstall(IDictionary savedState)
{
//安装物理目录
    string LogicDir = Context.Parameters["LogicDir"];
//安装虚拟目录
    string VitualDir = Context.Parameters["VitualDir"];
//处理自定义部分的安装内容,如数据库等
    base.Uninstall(savedState);
}


完成了这一系列动作后,整个程序的安装雏形已经基本OK,只要在相应的地方加入实际安装中所需要进行的一系列Action就可以制作一个完整的安装部署程序。 

注意事项: 

1、Resource文件属于项目的源文件,而非内容文件,所以如果项目中有Resource文件存在,则需要添加项目的源文件输出,同时利用排除筛选器设置好对*.cs文件和*.resx文件的过滤。
 
2、Bin目录默认不在web项目中,所以打包还需要加入web项目的主输出或直接把bin目录下的文件加入到web项目中,这样生成的dll会包含在内容文件输出中。 

3、安装制作过程中某些目录可能会无法创建(偶没能找到具体原因,估计是因为文件依赖性的缘故),则可以手工在Web应用程序文件夹中直接创建。

posted on 2008-08-12 16:54  ct  阅读(2273)  评论(0编辑  收藏  举报