WebEnh

.net7 mvc jquery bootstrap json 学习中 第一次学PHP,正在研究中。自学进行时... ... 我的博客 https://enhweb.github.io/ 不错的皮肤:darkgreentrip,iMetro_HD
随笔 - 1079, 文章 - 1, 评论 - 75, 阅读 - 174万
  首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

Winform程序在VS中打包成安装程序(带卸载)

Posted on   WebEnh  阅读(1230)  评论(1编辑  收藏  举报

场景

在VS中进行Winform开发时,可以直接在项目上右击选择生成

 

 

则会在项目的bin目录下直接生成exe等文件,此时将这个文件夹直接整个复制到别的地方就可以运行。

 

 

但是如果将其做成安装包安装的形式,并且还可以进行卸载应该怎么实现。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

1、需要VS安装扩展Microsoft Visual Studio Installer Projects,打开VS-管理扩展-搜索install

 

 

安装之后需要重新,这里是VS2019,重启之后等待安装完成。

 

 

2、在当前解决方案下添加-新建项目-Setup Project

 

 

3、项目添加成功之后-右击Application Folder(应用程序文件夹)-Add-文件

找到上面项目生成后的bin目录下所有的文件,添加进来

 

 

添加完之后

 

 

4、添加卸载程序,还是Application Folder下-Add-文件-找到C://Windows/System32下的msiexec.exe。

 

 

 

然后右击添加的msiexec.exe文件-点击Create Shortcut to misexec.exe

 

 

 

然后会得到一个Shortcut to msiexec.exe

5、点击新建的安装程序的项目,查看其ProductCode属性

复制该productCode的值

右击上面这个Shortcut to msiexec.exe,修改其Arguments属性为

/X空格复制的productCode值

注意这里有个空格

 

 

然后将这个Shortcut to msiexec.exe拖动到User's Program Menu(用户的程序菜单)

 

 

6、右击Application Folder-Add-项目输出

选择项目-主输出-确定

 

 

得到主输出 from badaoDemo(Active),在其上面右击-Create Shortcut to 主输出 from badaoDemo(Active)

 

 

然后将Shortcut to 主输出 from badaoDemo(Active)拖动到User's Destop目录下

 

 

这就是程序的快捷方式,可以更改其名字和图标等。

7、如果项目需要指定的环境,可以右击Setup1项目-属性-Prerequisites,选择必须的组件

 

 

8、右击Setup1项目-生成

 

 

此时在项目的bin目录下就有安装程序setup.exe了

 

 

双击该exe进行安装

 

 

安装之后在桌面就有快捷方式了,双击快捷方式启动

 

 

卸载的话直接在控制面板中找到进行卸载即可

 

 

博客园: https://www.cnblogs.com/badaoliumangqizhi/ 关注公众号 霸道的程序猿 获取编程相关电子书、教程推送与免费下载。
相关博文:
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
历史上的今天:
2016-12-04 .NET Core 跨平台发布(dotnet publish)
2016-12-04 Asp.Net Core 发布和部署(Linux + Jexus )
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

了解更多