1,无法有效避免非法的下载

使用ClickOnce部署,你的软件的更新版可以发布到Web服务器上,当用户从开始菜单启动软件时,ClickOnce自动到指定的URL去检测是否存在新版本,并且从这个地址下载最新版本。问题在于,访问这个URL的过程是ClickOnce的内部机能,不和用户产生任何交互,也就没法进行有效的用户验证,要想ClickOnce正常更新,就必须保证这个URL能够任意访问。导致任何人只要在浏览器输入这个URL,就可以下载程序。

我没有找到好的解决方法,只能尽量加强软件本身的验证机制,即使有人非法下载安装了你的程序,让他无法使用也就罢了。

2,.NET Framework安装的烦恼

使用ClickOnce可以自动验证客户端PC是否安装了必需的.NET Framework以及其版本,并且可以自动启动一个下载程序从微软网站取得最新的安装文件。这是一个很有用的功能,一般情况下很难说服用户先去微软网站自己安装.NET Framework,大多数用户甚至根本不想知道什么是Framework(很难和他们解释清楚,为什么安装一个很小的软件,需要先安装一个几百兆大的叫做Framework的鬼东西)。然而在实际测试中发现了一个问题,用户的PC在公司内部通过代理才能访问互联网,不知什么原因,自动下载程序访问微软网站的速度慢到无法接受的程度,大约200M的Framework,60个文件,自动安装整整花费了一个多小时,远远不如自己直接下载安装包手动安装来的快。

幸好ClickOnce提供了一个选项,你可以把Framework和程序同时发布到自己的服务器上---但是,由于Visual Studio 2008的一个小Bug,这个选项是不好用的,你需要首先参考【Visual Studio 2008 Service Pack 1 (SP1) Realease Note】这个文档的2.3.1.1章节,手动修复这个小问题---现在你可以把Framework也发布到同一台服务器上进行下载了,只要你对自己服务器的速度有信心。

目前ClickOnce的下载机能不是很智能,不能断点续传:我这边碰到的一个情况就是由于服务器端的某代理软件的吞吐量不够,下载过程中失败的几率很高;另外如果是分布在多个地域的用户,不一定从哪里下载比较快,可能有的人反而访问微软官方网站比较快,但是ClickOnce并没有办法动态切换Framework下载地址。问题的关键是这个Framework自动下载安装的过程,没法灵活干预,只有在最理想的网络环境中才能真正发挥其优点。

3,.NET Framework安装的另一个烦恼

解决了上面的问题,我已经把软件和.NET Framework都部署在Web服务器上,鼠标一点,似乎一切都顺利。然而随着安装软件的用户数越来越多,自动安装过程中发生莫名错误

的投诉电话也越来越多。问题的原因在于,有些PC里面已经安装过不同版本Framework3.5SP1,但是又和我发布的版本不尽相同,比如没有语言包等等,ClickOnce没有办法自动覆盖安装。

Framework安装版本冲突的问题其实很常见,一般性的解决办法就是从控制面板删除现有的版本之后重启计算机,再重新安装即可。仍然不行的话可以借助微软官方提供的.NET Framework Cleanup工具彻底删除既存版本。但是这种解决方式对于最终用户来说不可接受,他们需要的是真正的ClickOnce:点击一下,帮我解决所有问题。

早知今日后悔当初,不该给用户一个过高的期望值,从一开始就教育他们老老实实的手动安装Framework就好了。

4,安装目录和卸载

软件投入使用后,用户投诉说,每次版本升级,都会经过很长时间的停顿才能看到程序的启动画面。调查之后发现:ClickOnce部署的程序会安装在C:/Documents and Settings/用户名/Local Settings/Apps/2.0文件夹下的一个随机生成的目录中。版本升级的时候,并不会直接把老版本删除,而是会随机生成另外一个目录,并且将现有的用户数据文件原封不动的复制过去。如果需要,可以在【控制面板-添加安装程序】中恢复到老的版本继续使用。程序卸载的时候,这个目录会自动被清空。

问题在于,我的这个软件启动后生成保存了数百个XML格式的模板文件和数据文件,大量小文件的磁盘复制操作非常耗时。开发和测试用的PC性能较好停顿还不太明显,不凑巧用户使用的是比较旧的笔记本电脑,结果版本升级过程变得非常明显地缓慢。

为了解决这个问题,可以把数据文件存放在一个独立的文件夹中,可是在卸载的时候,由于这些数据文件不属于ClickOnce的安装目录,也就不能自动删除。如果ClickOnce部署的程序在卸载的时候,能够调用一些自定义的处理就好了。

5,又有新问题了

有一天有个用户搬着他的笔记本电脑来到一个穷乡僻壤,这里没有宽带,只能用一个56K的小猫上网。当他打开软件想工作的时候,ClickOnce提醒他,软件有了更新的版本,你是要安装呢还是暂时跳过?由于对56K小猫的下载速度不太有信心,他选择了跳过:反正软件的旧版本也可以继续使用,还是先完成工作要紧。过了几天,这个用户回到了宽带社会,心想现在可以升级版本了,可是当他再次打开软件,却没有任何关于新版本的提示信息。

尽管我不太理解,ClickOnce就是这样工作的:如果你选择了【跳过】某个版本,那么你就永远【跳过】这个版本了,除非有比之更新的版本发布了,ClickOnce才会再次提醒你升级。如果是我的话,我会给用户提供【暂时跳过】和【不要再提醒我这个版本的更新】两个选择,可惜微软的技术人员似乎没有我这样善解人意。

这个问题的解决办法就是用代码的方式调用ClickOnce的API,强制其再次进行版本更新。可以参考MSDN的文章:【如何:使用 ClickOnce 部署 API 以编程方式检查应用程序更新】,但这种方式不太友好,更新过程中缺少一个可视化的进度显示,所以你可以参考MSDN的另一篇技术文章【执行异步更新】。

尽管MSDN提供了完美的编程示例,但是真实世界往往和示例有很大差距,我准备在另一篇文章里面专门探讨一下以API方式进行ClickOnce更新的时候会碰到的各种问题。

6,关于证书的两个问题

第一,发布时候用的测试用证书有个有效期问题,一年之后会导致无法继续更新。所以我发布之前干脆把证书取消掉了,似乎也没有问题,用户安装软件的时候会有个警告。第二,如果ClickOnce从https的地址更新,一定得保证服务器证书的有效性。如果从浏览器访问这个网址会弹出证书有效性的警告,ClickOnce的更新会失败。前几天碰到一台客户端PC,没有安装Windows的根证书(IT部门的人装系统的时候自作聪明把他认为不必要的组件都给省略了),无法验证服务器端证书的有效性,导致ClickOnce的更新不能进行。

7,设置选项虽然多,但对应实际需求的灵活性不足

ClickOnce的高级设置选项很多。所以当初选择用ClickOnce部署的时候没考虑到其实这些选项的灵活性不大,很难应付实际需求,特别是碰到对操作性,爱钻牛角尖的用户。
用户最后提出来的具体要求实际上是:
1,启动前进行更新;
2,网速过慢,更新过程过于耗费时间的时候,在途中可以随时取消掉,使用老版本启动;
3,用户工作完毕,软件关闭的时候,把刚才取消掉的更新重新执行一次。因为这时候不着急工作了,可以慢慢下载

单纯使用ClickOnce的选项设置根本无法实现这样的需求,而全部抛弃ClickOnce也为时已晚,最后只好取消掉选项设置里的自动更新,完全采用编码方式调用API的方式进行更新。过程中虽然遇到各种各样的小问题,好在最后基本实现了用户的要求。

不过这也是微软产品的特性:使用方便,看似强大...不灵活

转:在决定使用ClickOnce发布你的软件前,应该知道的一些事情(一些常见问题解决方法)的更多相关文章

  1. Web Deploy发布网站及常见问题解决方法(图文)

    Web Deploy发布网站及常见问题解决方法(图文) Windows2008R2+IIs7.5 +Web Deploy 3.5 Web Deploy 3.5下载安装 http://www.iis.n ...

  2. ClickOnce发布注意的一些细节

    细节1.应用程序启动前检查更新: 步骤:主工程-右键属性-发布(页面)-按“更新”按钮-勾选“应用程序应该检查更新(T)”-选择“应用程序启动前(F)”,如下图: 细节二:ClickOnce发布时&q ...

  3. clickonce发布winform必备组件

    ClickOnce 发布,在系统必备中勾选了 .NET Framework 4,并选择了"从与我的应用程序相同的位置下载系统必备组件"时,执行发布,会提示缺少很多文件 使用 Pac ...

  4. Winform程序部署方式总结一——ClickOnce发布

    针对Winform程序,介绍两种常用打包方式:ClickOnce和Windows Installer 应用程序如下: 一.ClickOnce发布 1.找到需要发布的项目文件,右击,从弹出的快捷菜单中找 ...

  5. 使用ClickOnce发布Windows应用程序

    前言 因本人工作需要,在一名非常非常好的老师的指导下,入门了C#,再次向老师表示感谢. 本人平时经常遇到的业务就是将数据下发给各部门,并让各部门再上报,此过程中经常会遇到数据格式不正确,数据错误等诸多 ...

  6. 国家发改委发布的数据,前三季度我国生产的手机、PC、集成电路、宽带上网的数量

    集微网消息,根据国家发改委发布的数据,前三季度,我国生产集成电路944亿块,同比增长18.2%. 此外,前三季度,生产手机15亿部,同比增长17.6%,其中智能手机11亿部,增长12.1%,占全部手机 ...

  7. MVC4发布到IIS,出现HTTP 错误 404.0 - Not Found的解决方法

    MVC4发布到IIS,出现HTTP 错误 404.0 - Not Found的解决方法 1.出现的错误页面

  8. 用DllImport引用的外部DLL文件如何通过clickonce发布

    在.net中非托管代码或非COM组件的外部DLL文件只能用DllImport的方式使用,但是在clickonce方式发布时不会自动包含到发布清单中去,办法是在项目中先把外部DLL文件作为普通文件添加进 ...

  9. ClickOnce发布后不能安装

    当在internet发布用ClickOnce打包的客户端程序时,遇到ClickOnce启动后出错,错误信息如下: + Downloading https://xxxxx/Deploy/pc/Boote ...

随机推荐

  1. Maven 学习笔记(二)

    项目最近开始使用maven去管理项目啦,说真的对于maven是一窍不通啊,今天和同事在回家的路上聊天的时候同事说他去第一家公司面试的时候人家问他 maven 怎么打包,当时我就懵逼了,因为我也不知道啊 ...

  2. 删除none 的images报错 image has dependent child images 解决办法

    这个错是因为在要删除的images之后创建了该images的父images 方法: docker image inspect --format='{{.RepoTags}} {{.Id}} {{.Pa ...

  3. tensorflow语法笔记

    1.如何理解 tf.reduce_max或者 tf.reduce_mean中对Tensor和高维矩阵的坐标轴axis的选择的操作 tf.reduce_mean( input_tensor, axis= ...

  4. springboot-3-其他配置

    1, 热部署: 有jrebel的话, 不用了, 不如jre好用 原理: 使用两个classLoad, 一个加载不改变的jar, 另一个加载可更改的jar, 发生改变后, 舍弃可更改的jar重新rest ...

  5. springboot 常用插件

    热部署 使用run as -java application, 把spring-loader-1.2.4.RELEASE.jar下载下来,放到项目的lib目录中,然后把IDEA的run参数里VM参数设 ...

  6. Tornado异步IO

    Tornado提供了强大的异步IO机制,提高了服务器的响应能力. @tornado.web.asynchronous tornado默认在处理函数返回时关闭链接,@tornado.web.asynch ...

  7. 快排,归并和Shell排序

    快速排序 快速排序的执行流程: (1) 先从数列中取出一个数作为基准数. (2) 将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边. (3)再对左右区间重复第二步,直到各区间只有一个数. ...

  8. SQL2008无法连接到(local),该账户当前被锁定,所以Sa用户登陆失败

    1 安装小结 换了电脑,很多软件都得重装,期间报了很多问题,比如说先装vs2008再装sql server2008r2会报一个“存在2008早期版本”,通过查找,百度一系列的坑爹之路后,我还是把vs2 ...

  9. 使用docker-compose 部署服务 上

    转自:https://www.cnblogs.com/neptunemoon/p/6512121.html 使用docker-compose 大杀器来部署服务 上 使用docker-compose 大 ...

  10. mvc中的action验证登录(ActionFilterAttribute)

    方法一 :  1.创建一个全局action过滤器  (在appstart  的filterconfig中注册   filters.Add(new LoginAttribute());)  2.不需要登 ...