winform程序自动更新我也是第一次做,网上找了自动更新的源码,后来又根据在网上看到的一些方法,自己试了很久,最终还是有写错误,所以花了钱让别人帮忙调试成功的,下面是我自己捣腾出来的,方便大家借鉴,如果有什么错误的地方欢迎指正.
1、由于我是通过服务器的iis发布自动更新的,更新之前先手动把程序复制到iis服务器的目录下面,做一些更改,客户端才能正常自动更新。所以第一步是不熟iis服务器(本人系统windows8):
按照上面的方式,选了之后点确定,系统会自动添加这些内容,然后:
#1aae76338b529bf9ce2435b21929abfc#
网站建立好了之后,把写好的需要更新的文件放入你选的物理路径对应的文件目录下面就ok。
2、网站建立好了,那么下面就是要想办法搞更新了,也就是从服务器更新文件到客户端,至于具体的过程和中心思想我就不赘述了,网上很多。
3、自动源码下载地址找不着了,如果有需要的,请留邮箱,我再发.
4、把自动源码生成类库,然后在你的主程序引用该类库,把下图的两个文件和你的主程序放在同一个文件夹下面:
5、主程序的调用,在主程序里面调用我是放到登录窗体之前的,由于我没办法控制程序是否需要更新,所以我需要建立一个过程,就是在数据库建立一个表,包括两个字段
如上图,new字段是保存最新的版本,old是保存前一次的版本.。
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
using mulaolao.forms;
using mulaolao.procedure;
using system;
using system.collections.generic;
using system.linq;
using system.threading.tasks;
using system.windows.forms;
using mulaolao.other;
using system.threading;
using studentmgr;
using system.data;
using system.data.sql;
using system.data.sqlclient;
namespace mulaolao
{
static class program
{
//private static mutex mutex;
/// <summary>
/// 应用程序的主入口点。
/// </summary>
[stathread]
static void main( )
{
application.enablevisualstyles( );
application.setcompatibletextrenderingdefault( false );
//读取表
datatable da = sqlhelper.executedatatable( "select * from r_updatefororder" );
string news = "" , old = "" ;
//如果表中没有任何数据,则直接登录,不用更新
if (da.rows.count < 1)
{
//设置登录成功之后关闭登录窗体 显示主窗体
login lg = new login( );
lg.startposition = formstartposition.centerscreen;
lg.showdialog( );
if (lg.dialogresult == dialogresult.ok)
{
application.run( new form1( ) );
}
else
{
return ;
}
}
else
{
//如果表中的新版本和老版本一致,也不需要更新
news = da.rows[0][ "new" ].tostring( );
old = da.rows[0][ "old" ].tostring( );
if (news == old)
{
//设置登录成功之后关闭登录窗体 显示主窗体
login lg = new login( );
lg.startposition = formstartposition.centerscreen;
lg.showdialog( );
if (lg.dialogresult == dialogresult.ok)
{
application.run( new form1( ) );
}
else
{
return ;
}
}
else
{
//如果表中的新版本和老版本不一致 则需要把老版本更新成新版本 同时启动自动更新窗口
sqlhelper.executenonquery( "update r_updatefororder set old=@old" , new sqlparameter( "@old" , news ) );
system.diagnostics.process.start( application.startuppath + @"\autoupdate.exe" );
}
}
}
}
}
|
下一步即可,完成之后会自动启动更新后的主程序。
6、说说updatelist.xml里面的主要参数:
下面这个是我写的更新版本(表中new字段)的程序,放在客户端,第三张图里面的版本更新文件夹里面,每次更新服务器之前先运行这个程序,更新数据库最新版本:
以上内容就是我自己花了钱折腾出来的不怎么先进的方法,没办法,谁让自己入行不久,没什么经验,自己也搞不出先进的来,欢迎大家及时指正。其实主要的步骤:先建立iis服务器-->新建网站-->把主程序文件、更新文件、版本更新一股脑放在同一个文件夹下面-->主程序调用更新程序(主要是判断什么时候进行自动更新)-->把自动更新文件里面的参数配置好-->数据库里面的版本对照表建好-->更新之前在服务器覆盖住程序,修改自动更新xml文件内容,运行版本更新-->等待客户端自己更新
原文链接:http://blog.csdn.net/zhaozhimao/article/details/50084387