雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C#教程

當(dāng)前位置:主頁 > 軟件編程 > C#教程 >

c# Winform 程序自動(dòng)更新實(shí)現(xiàn)方法

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C#教程|點(diǎn)擊:

Winform程序自動(dòng)更新我也是第一次做,網(wǎng)上找了自動(dòng)更新的源碼,后來又根據(jù)在網(wǎng)上看到的一些方法,自己試了很久,最終還是有寫錯(cuò)誤,所以花了錢讓別人幫忙調(diào)試成功的,下面是我自己搗騰出來的,方便大家借鑒,如果有什么錯(cuò)誤的地方歡迎指正.

1、由于我是通過服務(wù)器的IIS發(fā)布自動(dòng)更新的,更新之前先手動(dòng)把程序復(fù)制到IIS服務(wù)器的目錄下面,做一些更改,客戶端才能正常自動(dòng)更新。所以第一步是不熟IIS服務(wù)器(本人系統(tǒng)windows8):

按照上面的方式,選了之后點(diǎn)確定,系統(tǒng)會(huì)自動(dòng)添加這些內(nèi)容,然后:

網(wǎng)站建立好了之后,把寫好的需要更新的文件放入你選的物理路徑對應(yīng)的文件目錄下面就OK。

2、網(wǎng)站建立好了,那么下面就是要想辦法搞更新了,也就是從服務(wù)器更新文件到客戶端,至于具體的過程和中心思想我就不贅述了,網(wǎng)上很多。

3、自動(dòng)源碼下載地址找不著了,如果有需要的,請留郵箱,我再發(fā).

4、把自動(dòng)源碼生成類庫,然后在你的主程序引用該類庫,把下圖的兩個(gè)文件和你的主程序放在同一個(gè)文件夾下面:

5、主程序的調(diào)用,在主程序里面調(diào)用我是放到登錄窗體之前的,由于我沒辦法控制程序是否需要更新,所以我需要建立一個(gè)過程,就是在數(shù)據(jù)庫建立一個(gè)表,包括兩個(gè)字段

如上圖,New字段是保存最新的版本,Old是保存前一次的版本.。

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>
  /// 應(yīng)用程序的主入口點(diǎn)。
  /// </summary>
  [STAThread]
  static void Main( )
  {
   Application.EnableVisualStyles( );
   Application.SetCompatibleTextRenderingDefault( false );
   //讀取表
   DataTable da = SqlHelper.ExecuteDataTable( "SELECT * FROM R_UpdateforOrder" );
   string news = "", old = "";
   //如果表中沒有任何數(shù)據(jù),則直接登錄,不用更新
    if (da.Rows.Count < 1)
   {
    //設(shè)置登錄成功之后關(guān)閉登錄窗體 顯示主窗體
    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)
    {
     //設(shè)置登錄成功之后關(guān)閉登錄窗體 顯示主窗體
     Login lg = new Login( );
     lg.StartPosition = FormStartPosition.CenterScreen;
     lg.ShowDialog( );
     if (lg.DialogResult == DialogResult.OK)
     {
      Application.Run( new Form1( ) );
     }
     else
     {
      return;
     }
    }
    else
    {
     //如果表中的新版本和老版本不一致 則需要把老版本更新成新版本 同時(shí)啟動(dòng)自動(dòng)更新窗口
      SqlHelper.ExecuteNonQuery( "UPDATE R_UpdateforOrder SET Old=@Old", new SqlParameter( "@Old", news ) );
     System.Diagnostics.Process.Start( Application.StartupPath + @"\AutoUpdate.exe" );
    }
   }
   
  }
 }
}

下一步即可,完成之后會(huì)自動(dòng)啟動(dòng)更新后的主程序。

6、說說UpdateList.xml里面的主要參數(shù):

下面這個(gè)是我寫的更新版本(表中New字段)的程序,放在客戶端,第三張圖里面的版本更新文件夾里面,每次更新服務(wù)器之前先運(yùn)行這個(gè)程序,更新數(shù)據(jù)庫最新版本:

以上內(nèi)容就是我自己花了錢折騰出來的不怎么先進(jìn)的方法,沒辦法,誰讓自己入行不久,沒什么經(jīng)驗(yàn),自己也搞不出先進(jìn)的來,歡迎大家及時(shí)指正。其實(shí)主要的步驟:先建立IIS服務(wù)器-->新建網(wǎng)站-->把主程序文件、更新文件、版本更新一股腦放在同一個(gè)文件夾下面-->主程序調(diào)用更新程序(主要是判斷什么時(shí)候進(jìn)行自動(dòng)更新)-->把自動(dòng)更新文件里面的參數(shù)配置好-->數(shù)據(jù)庫里面的版本對照表建好-->更新之前在服務(wù)器覆蓋住程序,修改自動(dòng)更新xml文件內(nèi)容,運(yùn)行版本更新-->等待客戶端自己更新

上一篇:C#中序列化實(shí)現(xiàn)深拷貝,實(shí)現(xiàn)DataGridView初始化刷新的方法

欄    目:C#教程

下一篇:c#動(dòng)態(tài)類型,及動(dòng)態(tài)對象的創(chuàng)建,合并2個(gè)對象,map實(shí)例

本文標(biāo)題:c# Winform 程序自動(dòng)更新實(shí)現(xiàn)方法

本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5886.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有