net制作安装程序总结(WinForm,WebForm) 整理

2024-03-07 09:08

本文主要是介绍net制作安装程序总结(WinForm,WebForm) 整理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、创建基本安装部署项目

1.         在解决方案资源管理器,右击解决方案à添加à新建项目à安装部署项目àWeb安装项目,例如命名为WebSetup。

2.         右击WebSetup项目à视图à文件系统。

(1)添加你所需要安装的Web程序(例如:WebApp)。在文件系统中右击Web应用程序文件夹à项目输出à选择WebApp,同时选种主输出何内容输出。

(2)添加相关的文件,例如.jpg 、.xml等文件(根据帮助可知这些文件无法自动添加到安装文件中),注意:原文件怎么样存放的,添加时也要以同样的文件夹存放。

例如,原文件存放在//aa/cc/bb.txt,则添加文件bb.txt时也应如此,右击web应用程序文件夹à添加web文件夹(命名为aa)à右击aaà添加web文件夹(命名为cc)à右击ccà添加文件(bb.txt).

3.         右击WebSetup项目à视图à用户界面。

1)        添加你所需要的界面。安装à启动à添加对话框à文本框(A),如果添加了文本框则必须要上移(右击要上移的文本框à上移)到安装地址之上。

2)        如果有许可协议对话框,则在文件系统中要添加一个.rtf格式的文件

注意改文件一定要时通过word另存为.rtf格式得到,不可以通过记事本创建文件后把扩展名改为.rtf而得到,那样将不显示许可协议),右击许可西医对话框à属性à把licenseFile属性选为你所要添加的许可协议文件。

(属性BannerBitmap 安装对话框中的图片;Sunken 是否凹凸显示。其他对话框相同)

以上是安装文件制作的基本过程。如果要安装数据库,和用户自定义的一些操作如下:
二、添加自定义操作----安装数据库
1)        在用户界面添à右击à添加对话框文本框(A)如果添加了文本框则必须要上移(右击要上移的文本框à上移)到安装地址之上。
2)        如果只安装一个数据库就把其Edit2Visible,Edit3Visible,Edit4Visible设置为false.把Edit1property定义一个变量名,例如PARA1。  
 3) 自定义用户操作,在资源管理器界面右击资源管理器à新建àC#(也可以是VB.NET),选择类库,命名为WebInstall 。
 4) 新建项目会自动生成一个class1.cs文件,把次文件删除。右击WebInstall添加新项à安装类,命名为Install.cs。
5)右击Install.csà视图设计界面,然后在服务器资源管理器中添加数据库master的连接,添加好后把这个连接拖到Install的设计界面。

6)在Install.cs文件中添加以下代码

       注:要添加应用添加应用

using System.Reflection;

using System.Data;

using System.Data.SqlClient;

using System.IO;

安装数据库代码

    ///<summary>

        ///获得配置文件中嵌入的文本文件

        ///</summary>

        ///<param name="Name">文件名</param>

        ///<returns></returns>

        private string GetSql(string Name)

        {          

            Assembly Asm = Assembly.GetExecutingAssembly();

            Stream strm = Asm.GetManifestResourceStream(Asm.GetName().Name + "."+Name);

            StreamReader reader = new StreamReader(strm);

            return reader.ReadToEnd();

        }

 

        ///<summary>

        ///指定的数据库执行SQL语句

        ///</summary>

        ///<param name="DatabaseName">数据库名</param>

        ///<param name="sqlstring">SQL语句</param>

        ///<returns></returns>

        private void ExecuteSql(string DataBaseName,string sqlstring)

        {

            System.Data.SqlClient.SqlCommand Command = new System.Data.SqlClient.SqlCommand(sqlstring,sqlConn);

 

            Command.Connection.Open();

            Command.Connection.ChangeDatabase(DataBaseName);

            try

            {

                Command.ExecuteNonQuery();

            }

            finally

            {

                Command.Connection.Close();

            }

 

        }

 

        ///<summary>

        ///创建数据库及数据库表

        ///</summary>

        ///<param name="DBName">数据库名</param>

        ///<param name="assemblyName">配件中数据库脚本资源的名称</param>

        ///<returns></returns>

        protected bool CreateDBAndTable(string DBName)

        {

            bool Restult = false;

            try

            {

                    ExecuteSql("master","CREATE DATABASE " + DBName);

                    ExecuteSql(DBName,GetSql("bbssql.txt"));

                    Restult = true;

           

            }      

            catch(Exception ex)

            {

//次段代码为调试用可以不添加

 

                StreamWriter sw = new StreamWriter(@"c:/SrInforSys.txt");

                sw.WriteLine("[SrInforSys案装错误]");

                sw.WriteLine(ex.Message.ToString());               

                sw.Close();                    

    }

            return Restult;

        }

       

           

        ///<summary>

        ///安装数据库

        ///</summary>

        ///<param name="stateSaver"></param>

        public override void Install(IDictionary stateSaver)

        {

            base.Install (stateSaver);

            if(!CreateDBAndTable(this.Context.Parameters["dbname1"].ToString()))

                throw new ApplicationException("创建数据库时出现严重错误!");

        }

在添加安装数据库时一定要有创建数据库的脚本,并且把它存为.txt文件添加到WebInstall项目中了,右击该文件(例如,database.txt)à属性à生成操作,该为嵌入资源(这点很中要)

7)生成WebInstall.dll文件。在解决方案资源管理器中右击àWebSetup项目à视图à在文件系统,右击Web应用程序文件夹à添加à项目输出à选择WebInstall(主输出)à确定

8)在解决方案资源管理器中右击àWebSetup项目à视图à自定义操作,在自定义操作界面区中右击安装à添加自定义操作à在Web应用程序文件夹à主输出来自WebInstall(活动)

添加完后右击主输出来自WebInstall(活动)à属性,把customeActionData设置为/dbname=[PARA1](此处的dbname为要接受的参数名,PARA1就是前面添加的文本框中Edit1property)。

9)编译WebSetup程序就可以了。

如果有两个或者多个数据库时,就把文本框的其他输入框设置为true(Edit2Visible, Edit3Visible , Edit4Visible),并且在自定义操作中把customeActionData属性改为/dbname1=[PARA1] /dbname2=[PARA2] /dbname3=[PARA3] /dbname4=[PARA4](有几个写几个)中间必须用一个空格分隔。

三、添加启动条件

在安装我们做好的程序总是要有一些启动条件的,例如必须有.net framework, SQL等。以下就以这SQL为例子

1)在解决方案资源管理器中右击àWebSetup项目à视图à启动条件à目标计算机上的要求à添加注册表启动条件à把名字改为search of SQLà属性,更改其属性
Property----------------SEARCHOFSQL
RegKey----------------SOFTWARE/Microsoft/MSSQLServer/Setup(指定要搜索的表项 )
Root--------------------vsdrrHKLM(指定要搜索的注册表根)
Value-------------------SQLPath(要搜索的注册表值)
2)在启动条件界面,右击启动条件à添加启动条件命名为SQL Server,更改属性
Condition--------------- SEARCHOFSQL
Message-----------------您本机上没有SQL Server 2000,请先安装!

如果添加其他的启动条件类似。

四、卸载程序

1)在WebInstall项目中的Install.cs中添加如下代码

private bool DeleteDatabase()

         {

              try

              {   

                   ExecuteSql(此方法就时前面案扎数据库的方法)("master","USE MASTER IF EXISTS (SELECT NAME FROM SYSDATABASES WHERE NAME=aa) DROP DATABASE aa");

                   return true;

              }

              catch

              {

                   return false;

              }

         }       

public override void Uninstall(IDictionary savedState)

         {

              if (savedState == null)

                   throw new ApplicationException("未能卸载!");

              else

              {

                   base.Uninstall (savedState);

                   if(!DeleteDatabase())

                       throw new ApplicationException("卸载过程中发生错误,未能卸载!");

              }       

         }

2)WebSetup项目的自定义操作中,右击卸载à添加自定义操作à在Web应用程序文件夹à主输出来自WebInstall(活动)

 

五、添加删除垃圾文件

这一点不一定用的到,不过有一些老板认为做处来的安装程序太小了给用户看不时很好就添加一些垃圾文件,让安装程序变大点,安装完后又删除。

在WebInstall项目中的Install.cs中添加如下代码

 

     private void DeleteFile()

         {

              string stLocation;

              Assembly asm = Assembly.GetExecutingAssembly();

              stLocation = asm.Location;      

              stLocation = stLocation.Substring(0,stLocation.LastIndexOf("//")) +"//要删除的文件名";

              System.IO.File.Delete(stLocation);                

         }

(此文件事先添加到Web应用程序文件夹下)

DeleteFile()方法添加到 public override void Install(IDictionary stateSaver)中即可。

 

 
五、把.NET程序部署到没有安装.NET Framwork的机器上 http://www.microsoft.com/China/Community/program/originalarticles/TechDoc/deployNETApp.mspx
在微软官方网站下载Microsoft Visual Studio .NET 2003 引导程序插件
文件名叫: PluginInstaller.msi

下载地址:http://www.microsoft.com/downloads/details.aspx?FamilyID=627921a0-d9e7-43d6-a293-72f9c370bd19&displaylang=zh-cn

你安装了这个插件然后用IDE自带的安装部署即可,他会在你的安装包里另加三个文件:MDAC 2.8 和 .NetFramework 和中文语言包,并且自动判断系统是否已安装框架。
Microsoft Visual Studio .NET 2003制作安装程序  
http://dev.csdn.net/article/28/article/27/27847.shtm  
部署ASP.NET的三大技术
http://tech.ccidnet.com/pub/article/c295_a68309_p1.html  
在制作安装程序,不知如何才能将数据库结构及数据导入,高分求Duwamish7制作打包部署程序的源码及方法  
http://community.csdn.net/Expert/topic/3368/3368253.xml?temp=.7017328
项目打包时自定义安装属性,如数据库名等  
http://blog.csdn.net/greystar/archive/2004/08/17/76716.aspx
用Vs.net制作安装程序
http://www.showyou.net/MyCode/ArticleView/Article_4641.html  
自动安装SQL Server数据库  
http://www.cnblogs.com/wangsaokui/articles/9769.aspx
安装程序时读取路径的问题  
http://blog.joycode.com/fogshadow/archive/2004/04/30/20589.aspx  
asp.net打包的问题(1.修改文件夹访问权限;2.设置起始页  
http://community.csdn.net/Expert/topic/3380/3380589.xml?temp=8.585757E-02  

此文章转自CSDN,此处仅为收集。

 

 

这篇关于net制作安装程序总结(WinForm,WebForm) 整理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/783025

相关文章

Spring Boot 常用注解整理(最全收藏版)

《SpringBoot常用注解整理(最全收藏版)》本文系统整理了常用的Spring/SpringBoot注解,按照功能分类进行介绍,每个注解都会涵盖其含义、提供来源、应用场景以及代码示例,帮助开发... 目录Spring & Spring Boot 常用注解整理一、Spring Boot 核心注解二、Spr

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio