c# Winform 程序自動(dòng)更新實(shí)現(xiàn)方法
Winform程序自動(dòng)更新我也是第一次做,網(wǎng)上找了自動(dòng)更新的源碼,后來(lái)又根據(jù)在網(wǎng)上看到的一些方法,自己試了很久,最終還是有寫錯(cuò)誤,所以花了錢讓別人幫忙調(diào)試成功的,下面是我自己搗騰出來(lái)的,方便大家借鑒,如果有什么錯(cuò)誤的地方歡迎指正.
1、由于我是通過(guò)服務(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)站建立好了之后,把寫好的需要更新的文件放入你選的物理路徑對(duì)應(yīng)的文件目錄下面就OK。
2、網(wǎng)站建立好了,那么下面就是要想辦法搞更新了,也就是從服務(wù)器更新文件到客戶端,至于具體的過(guò)程和中心思想我就不贅述了,網(wǎng)上很多。
3、自動(dòng)源碼下載地址找不著了,如果有需要的,請(qǐng)留郵箱,我再發(fā).
4、把自動(dòng)源碼生成類庫(kù),然后在你的主程序引用該類庫(kù),把下圖的兩個(gè)文件和你的主程序放在同一個(gè)文件夾下面:
5、主程序的調(diào)用,在主程序里面調(diào)用我是放到登錄窗體之前的,由于我沒(méi)辦法控制程序是否需要更新,所以我需要建立一個(gè)過(guò)程,就是在數(shù)據(jù)庫(kù)建立一個(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 = ""; //如果表中沒(méi)有任何數(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、說(shuō)說(shuō)UpdateList.xml里面的主要參數(shù):
下面這個(gè)是我寫的更新版本(表中New字段)的程序,放在客戶端,第三張圖里面的版本更新文件夾里面,每次更新服務(wù)器之前先運(yùn)行這個(gè)程序,更新數(shù)據(jù)庫(kù)最新版本:
以上內(nèi)容就是我自己花了錢折騰出來(lái)的不怎么先進(jìn)的方法,沒(méi)辦法,誰(shuí)讓自己入行不久,沒(méi)什么經(jīng)驗(yàn),自己也搞不出先進(jìn)的來(lái),歡迎大家及時(shí)指正。其實(shí)主要的步驟:先建立IIS服務(wù)器-->新建網(wǎng)站-->把主程序文件、更新文件、版本更新一股腦放在同一個(gè)文件夾下面-->主程序調(diào)用更新程序(主要是判斷什么時(shí)候進(jìn)行自動(dòng)更新)-->把自動(dòng)更新文件里面的參數(shù)配置好-->數(shù)據(jù)庫(kù)里面的版本對(duì)照表建好-->更新之前在服務(wù)器覆蓋住程序,修改自動(dòng)更新xml文件內(nèi)容,運(yùn)行版本更新-->等待客戶端自己更新
相關(guān)文章
C#并發(fā)實(shí)戰(zhàn)記錄之Parallel.ForEach使用
這篇文章主要給大家介紹了關(guān)于C#并發(fā)實(shí)戰(zhàn)記錄之Parallel.ForEach使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08C#使用base64對(duì)字符串進(jìn)行編碼和解碼的測(cè)試
今天小編就為大家分享一篇關(guān)于C#使用base64對(duì)字符串進(jìn)行編碼和解碼的測(cè)試,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02