做了一個CS結構軟體,有十幾個用戶使用的客戶端,因為剛開始試用期間,要不斷根據用戶使用情況修正問題和添加新功能,所以頻繁更新是不可避免的,暫時沒有深入去研究軟體更新,暫時採取的方式是用戶通過FTP自行更新,這種方式很麻煩,最煩的是,常常有很多用戶忘記更新,而我預期的是一旦更新,每個客戶端都能自行更新... ...
做了一個CS結構軟體,有十幾個用戶使用的客戶端,因為剛開始試用期間,要不斷根據用戶使用情況修正問題和添加新功能,所以頻繁更新是不可避免的,暫時沒有深入去研究軟體更新,暫時採取的方式是用戶通過FTP自行更新,這種方式很麻煩,最煩的是,常常有很多用戶忘記更新,而我預期的是一旦更新,每個客戶端都能自行更新到最新版本。
後面想到使用微軟的ClickOnce,每次我將新版本軟體發佈到伺服器上,然後用戶再打開軟體的時候,ClickOnce會自行判斷軟體是否需要更新,然後通過點擊就可以實現更新,這樣無疑是非常好的。
不過經過我的實踐使用和搜索其他使用ClickOnce的人的經驗,雖然發現ClickOnce其實有很多問題的,不過一番研究下來,ClickOnce其實是能夠滿足我的簡單需求的,那麼後面就決定使用ClickOnce了。
下麵我將ClickOnce的用法以及遇到的一些疑點和解決方案寫出來,內容簡單,並沒有太過深入,希望會對其他有類似需求的朋友有一點幫助。
ClickOnce可以發佈WinForm或者WPF等客戶端程式,一般是發佈到公共的伺服器上,部署安裝直接給用戶發一個html地址,他們點擊這個地址就可以安裝了。
需要做的準備工作有:
提前在伺服器上開一個IIS網站站點,埠號可以使用空閑的,比如8001等(要設置防火牆允許,不然會被擋住),設置好程式池,對應文件夾訪問許可權,可以用一個自製的簡單html文件測試一下該站點是否OK。
然後設置一個到該站點對應文件夾的FTP服務,我使用的FTP伺服器軟體是Xlight,非常好用的軟體,極力推薦。FTP服務是為了方便以後你往伺服器上上傳新的客戶端部署文件用的。
接下來就是要在VS當中設定你要部署的項目屬性了。
打開項目的屬性頁,選擇發佈選項卡,如下圖:
發佈位置有兩個,第一個是【發佈文件夾位置】,意思就是你的軟體程式會被壓縮打包放到的地方,後續安裝就要用到這些文件,可以直接點擊後面的按鈕,選擇FTP或者本地,因為Click Once的FTP做的太簡陋了,發佈上傳速度十分感人,而且我在實際使用當中有時候會出現莫名奇妙發佈到其他地方的怪異現象,所以推薦選擇本地的一個文件夾,後續再自行上傳到伺服器地址。
第二個是【安裝URL】,這個地址就是後面實際用戶從什麼地方來安裝你的軟體,也就是你上面發佈的那些程式文件後面實際存放的位置,一般用戶是通過伺服器來安裝你的軟體的,所以一般這裡寫的是伺服器地址,我這裡地址埠後面的目錄是因為我在這個地址上要發佈多個軟體,所以用不同的目錄訪問區別一下。
安裝模式有兩種,一個就是只能聯機使用(每次用都要連接到你的安裝伺服器),一種就是可以離線使用(一時半夥連接不上安裝伺服器也可以,只是不能更新罷了),一般選擇第二種。
下麵發佈的版本號和你在程式集里設定的版本號不一樣的,這個版本號只是為了更新的目的。
每次客戶端檢測到安裝伺服器上的版本號比當前客戶端的號大,就會提示更新(和實際你的程式有沒有變動沒有關係),手動更改還是自動遞增結合自己的情況來選擇。
點擊應用程式文件會出現下麵的視窗
這裡就是你的項目中將要發佈給用戶的文件,基本上exe和dll都會包含進去,但是有些資源文件,比如圖片,其他文檔等,如果在這個列表當中沒有看到,就要會到項目資源管理器當中,右鍵設定他們的輸出屬性為內容,並且複製到目錄中,這樣就會在應用程式文件列表中看到它們了,對應的文件夾層次也會自動生成的(列表中看不到)。
接下來使用系統必備組件,這個很好理解,不詳細說了。
接下來是更新設定
上面的很清楚,不說了,下麵指定最低版本的意思就是允許運行的最低版本(低於這個版本,不更新不讓你用,有些用戶在有更新提示的時候會選擇不更新)
更新位置如果為空,預設就是安裝伺服器,如果你換其他伺服器來更新的話,就重新設定一下位置。
接下來是選項,有四個選項卡
說明部分下麵的支持url就是提供支持服務的網站,錯誤url就是程式出錯之後轉到的網址,一般不用填寫
部署網頁就是用戶頭一次安裝的時候需要打開的網站,名字自己擬定,發佈的時候會自動生成,訪問的時候通過192.168.16.254:8001/PMS/publish.html
清單,有用的是創建桌面快捷方式,快捷方式的圖標就是程式的圖標
如果需要關聯的文件的話,在這裡設定一下。
這些都設定好了之後就可以直接發佈了,發佈後的文件會在發佈設定的本地文件夾中(如果你設定了發佈文件夾的話)
然後將這些文件用FTP上傳到你設定的安裝伺服器的地址上,之後就可以通過192.168.16.254:8001/PMS/publish.html的地址進行訪問安裝了。
最後還要說的就是簽名
沒有正式的簽名證書就暫時不簽名了,簽名的作用都知道,沒有簽名在安裝的時候會出現風險警告提示,不過是自己知道可以信任,這時候一路確認就行了。
用戶第一次安裝完後,當有新的更新傳送到伺服器的上的時候,用戶在打開安裝好的客戶端的時候就會自動檢測版本,一旦發現需要更新,那麼就會自動提示下麵的信息。
一路確認即可。
以上就是Click Once的入門使用,希望能有幫助。
接下來再說說它的一些問題。
從MSDN上看,ClickOnce每次更新都是下載更改過的部分,然後從重新安裝,而且每個版本之間是獨立,不會互相影響,同時它對許可權控制的比較嚴格。
我查看過來,安裝的位置其實是在用戶文件夾下隱藏的C:\Users\用戶名\AppData\Local\Apps,配置和其他程式一樣都預設放在Local里,有些人覺得這個很不自由,但是除非你的程式對系統許可權有很多特殊的要求的話,還是按照微軟的設定走比較合理,印象中Chrome就是這麼設定的。
我認為,就一般需求來說,ClickOnce是能夠滿足需求的,如果有更多特殊的要求,就只能使用其他成熟的更新組件或者乾脆自己設計一個好了。