用VB6.0編寫自我升級的程序(三)

發表于:2007-07-01來源:作者:點擊數: 標簽:
VERSION 5.00 Begin VB .Form frmUpdate BackColor = H80000007 BorderStyle = 0 None Caption = "Form1" ClientHeight = 1185 ClientLeft = 0 ClientTop = 0 ClientWidth = 5400 LinkTopic = "Form1" MaxButton = 0 False MinButton = 0 False ScaleHeight

 

VERSION 5.00

Begin VB.Form frmUpdate

   BackColor       =   &H80000007&

   BorderStyle     =   0  ´None

   Caption         =   "Form1"

   ClientHeight    =   1185

   ClientLeft      =   0

   ClientTop       =   0

   ClientWidth     =   5400

   LinkTopic       =   "Form1"

   MaxButton       =   0   ´False

   MinButton       =   0   ´False

   ScaleHeight     =   1185

   ScaleWidth      =   5400

   ShowInTaskbar   =   0   ´False

   StartUpPosition =   2  ´屏幕中心

   Begin VB.CommandButton Command1

      Appearance      =   0  ´Flat

      Caption         =   "關閉"

      Height          =   435

      Left            =   2130

      TabIndex        =   0

      Top             =   630

      Visible         =   0   ´False

      Width           =   1245

   End

   Begin VB.Label lblCap

      AutoSize        =   -1  ´True

      BackStyle       =   0  ´Transparent

      BeginProperty Font

         Name            =   "宋體"

         Size            =   12

         Charset         =   134

         Weight          =   400

         Underline       =   0   ´False

         Italic          =   0   ´False

         Strikethrough   =   0   ´False

      EndProperty

      ForeColor       =   &H000000FF&

      Height          =   240

      Left            =   330

      TabIndex        =   1

      Top             =   150

      Width           =   120

   End

   Begin VB.Shape Shape1

      BackColor       =   &H00C0FFFF&

      BackStyle       =   1  ´Opaque

      BorderColor     =   &H0000FF00&

      Height          =   1065

      Left            =   60

      Top             =   60

      Width           =   5265

   End

End

Attribute VB_Name = "frmUpdate"

Attribute VB_GlobalNameSpace = False

Attribute VB_Creatable = False

Attribute VB_PredeclaredId = True

Attribute VB_Exposed = False

Option Explicit

 

´ ------------------------------------------

´ 升級程序的例子

´ 作者:   謝家峰

´ 日期:   2003/12/19

´

´ 這里是升級程序

´

´ ------------------------------------------

 

Dim State As Boolean

 

Private Sub Command1_Click()

  Unload Me

End Sub

 

Private Sub Form_Activate()

 

  Dim i As Integer

  Dim j As String

 

  Dim OldExeFile As String

  Dim NewExeFile As String

 

  Dim tmpFile As String

  Dim MainState As Boolean

 

 

  DoEvents

   

  If State Then

     ´ 獲取舊主程序名稱

     OldExeFile = CStr(ReadIniFile(UpdateIniPath, "Main", "Name", "主程序"))

     NewExeFile = OldExeFile

     OldExeFile = App.Path & "\" & OldExeFile & ".exe"

     tmpFile = App.Path & "\tmp.tmp"

    

     ´ 改寫升級次數

     i = CInt(ReadIniFile(UpdateIniPath, "Update", "Num", "0"))

     i = i + 1

     ChangeLabelPos Me, lblCap, "這是您第" & i & "次升級!"

     Sleep 1500

    

     ´ 摸擬從網站下載新的更新程序。

     ChangeLabelPos Me, lblCap, "正在 摸擬從網站下載新的升級程序 ..."

     Sleep 1000

     On Error Resume Next

     Kill tmpFile

     ´ 此處可以修改為將臨時文件放在臨時文件夾內

     SaveFileFromRes 101, "CUSTOM", tmpFile

     Sleep 1000

     On Error GoTo 0

    

     ´ 檢查主程序是否開啟,若開啟則關閉舊程序

     MainState = CBool(CInt(ReadIniFile(UpdateIniPath, "Main", "Active", "0")))

     If MainState Then

       ´ 關閉舊程序

       ChangeLabelPos Me, lblCap, "正在關閉舊程序 ... "

       Sleep 300

      

       ´ 這里強行關閉舊程序

       ´ 你也可以發送消息,讓舊程序自己關閉

       Do While -1

          DoEvents

          If CloseValidForm(NewExeFile) Then

             Exit Do

          End If

       Loop

       Sleep 200

     End If

    

     ´ 刪除舊程序

     On Error Resume Next

     ChangeLabelPos Me, lblCap, "正在刪除舊程序 ... "

     Sleep 1000

     Kill OldExeFile

     Sleep 1000

    

    

     ´ 生成新主程序名稱

´     NewExeFile = CStr(ReadIniFile(UpdateIniPath, "Main", "Name", "主程序"))

     j = Right(NewExeFile, 1)

     If IsNumeric(j) Then

        j = i

        NewExeFile = Left(NewExeFile, Len(NewExeFile) - 1)

     Else

        j = 1

     End If

     ´ 記錄主程序的名字

     NewExeFile = NewExeFile & j

     WritePrivateProfileString "Main", "Name", NewExeFile, UpdateIniPath

     NewExeFile = App.Path & "\" & NewExeFile & ".exe"

    

    

     ´ 拷貝新程序

     ChangeLabelPos Me, lblCap, "正在更新程序 ... "

     Sleep 1000

     FileCopy tmpFile, NewExeFile

     Sleep 1000

     ´ 刪除臨時程序

     Kill tmpFile

    

     ´ 記錄更新次數

     WritePrivateProfileString "Update", "Num", CStr(i), UpdateIniPath

    

     ´ 檢查舊程序的狀態

     If MainState Then

        ChangeLabelPos Me, lblCap, "正在啟動更新后的主程序 ... "

        Sleep 1000

        Shell NewExeFile, vbNormalNoFocus

     End If

    

     ´ 關閉更新程序

     Command1.Visible = True

     ChangeLabelPos Me, lblCap, "更新完成,請等待 3 秒后將自動關閉更新程序 ..."

     Sleep 3000

     lblCap.Refresh

    

     Unload Me

  End If

End Sub

 

Private Sub Form_Load()

 

  If App.PrevInstance Then End

 

  UpdateIniPath = App.Path & "\Update.ini"

  State = True

End Sub

 

 

完成了三個工程的代碼拷貝,在代碼的必要之處我都進行了詳細注釋,這里我就不再介紹代碼了,現在進行最后一步,模擬從網站下載升級后的程序。

a.        打開projMain.vbp,編譯該工程,并且命名為“主程序.exe”;

b.        打開projNewMain.vbp,編譯該工程,并且命名為“projNewMain.exe”;

c.        打開projUpdate.vbp,打開工具欄上的“vb資源編輯器”(若沒找到,讀者需要點擊菜單“外接程序|外接程序管理器”,在打開的對話框中選擇“vb6資源編輯器”,在加載行為中選擇“加載/卸載”復選框),在資源編輯器中選擇“添加自定義資源 …”,在打開的對話框中定位到Update文件夾,選擇projNewMain.exe文件,保存該資源文件,最后編譯該工程并且命名為“Update.exe”。

d.        將可執行文件“主程序.exe”、“Update.exe”拷貝到同一個文件夾中,運行任一個程序,相信讀者會看到效果。

 

以上代碼比較簡單,僅供讀者分析思路用。在實際工程中的代碼編寫時也根本沒必要把projNewMain.exe放在資源文件中,讀者只需將它放在服務器的某個位置,然后在projUpdate.vbp中的相應處寫下載代碼即可。

Ok,文章至此編寫完成,希望對各位讀者能有所幫助。

 

附:本人已在CSDN上發布了源碼,等管理員審核完畢,本人再將鏈接地址補上。

 


原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97