• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            為你的Cocoa應用程序加入更新支持:Sparkle 簡介

            發布于:2010-09-20 13:06閱讀數:3141

            作為一名桌面軟件開發者,應該提早考慮程序的更新問題。如何將程序更新及時優雅的推送給用戶,是維持用戶忠誠度和提高軟件使用體驗的一個重要方面。而作為Cocoa應用程序開發者,

            轉自 ibuick.com,原文  http://ibuick.com/index.php/archives/add-automatic-update-support-over-cocoa-app-via-sparkle-framework


            作為一名桌面軟件開發者,應該提早考慮程序的更新問題。如何將程序更新及時優雅的推送給用戶,是維持用戶忠誠度和提高軟件使用體驗的一個重要方面。而作為Cocoa應用程序開發者,我們可以選擇自己手動來實現此功能,也可以選擇一些優秀的開源框架。Sparkle就是其中之一。

            Sparkle是一個非常簡單且易用的Cocoa應用程序更新框架。本篇文章將使用一個簡單的例子,教你如何使用Sparkle為你的Cocoa應用程序加入更新支持。

            1: 新建一個Cocoa Application,TestSparkle

            wpid-wpid-xcodecocoaapplication-2010-09-10-16-11-2010-09-10-16-11.png

             

            wpid-wpid-cocoaapplicationwithsparkle-2010-09-10-16-11-2010-09-10-16-11.png
            2: 去到Sparkle下載Sparkle Framework,最新版本為 1.5b6,

            wpid-wpid-sparkle-2010-09-10-16-11-2010-09-10-16-11.png
            Sparkle Test App.app 是一個用來演示Sparkle更新框架的一個應用程序。

            Extras文件夾下提供了Sparkle的標準圖標,Release Notes模版,軟件簽名工具,源代碼和Appcast.xml示例文件,我們后面會再講到這些工具和文件。

            With Garbage Collection, 是一個加入了Garbage Collection支持的Sparkle分發版,如果你的應用程序運行在有GC的環境下,則可以使用這個版本的Sparkle

            Sparkle.framework 是通用分發版,筆者建議大家使用此版本的Sparkle。

            3: 鏈接Sparkle框架到TestSparkle工程

            拖拽Sparkle.framework(或 with Garbage Collection下的 Sparkle.framework)到TestSparkle的Linked Frameworks下,在彈出窗口中記得選中”Copy items into destination group’s folder (if needed)”前面的復選框。

            wpid-wpid-addsparkletotestsparkle-2010-09-10-16-11-2010-09-10-16-11.png

            4: 為你的工程新建一個Copy Files Build Phase,

            wpid-wpid-addcopyfilesbuildphase-2010-09-10-16-11-2010-09-10-16-11.png
            5: 右鍵點擊這個新建的Copy Files Build Phase,并在彈出窗口中,點擊Destination下拉框,選擇Frameworks

            wpid-wpid-copyfilesbuildphaseforframework-2010-09-10-16-11-2010-09-10-16-11.png
            6: 將Linked Framworks下的Sparkle.framework拖拽到這個新建的Copy Files Build Phase 中

            wpid-wpid-addsparkle-2010-09-10-16-11-2010-09-10-16-11.png
            7: 在Interface Builder中打開TestSparkle的MainMenu.xib(nib), 然后點擊Interface Builder–>Files–>Read Class Files

            wpid-wpid-readclassfiles-2010-09-10-16-11-2010-09-10-16-11.png

            8: 將Sparkle.framework中的所有頭文件選中并讀取

            wpid-wpid-readheaderfiles-2010-09-10-16-11-2010-09-10-16-11.png
            9: 從Library中拖拽一個 NSObject到MainMenu主窗口.

            wpid-wpid-addobject-2010-09-10-16-11-2010-09-10-16-11.png

            10: 點擊此Object對象,點擊Inspector,設定此Object的Class為 SUUpdater

            wpid-wpid-SUUpdater-2010-09-10-16-11-2010-09-10-16-11.png

            11: 添加一個菜單項到到TestSparkle Menu,重命名為 Check For Updates…

            wpid-wpid-Checkupdatesmenuitem-2010-09-10-16-11-2010-09-10-16-11.png

            12: 將 Check for Updates…菜單項的Send Actions指向Updater Object的checkForUpdates方法

            wpid-wpid-addactionforupdate-2010-09-10-16-11-2010-09-10-16-11.png
            13: 保存Interface Builder的所有更改,退出Interface Builder。

            14: 為了安全防止應用程序更新遭到惡意篡改,我推薦對應用程序更新添加數字簽名。

            Sparkle使用DAS SHA-1 來對程序更新包進行數字簽名。

            打開終端,進入步驟2中存放已下載的Sparkle包的文件夾,進入Extras–>Signing Tools,

            執行,

            ruby generate_keys.rb

            這個命令將會生成兩個文件 dsa_priv.pem 和 dsa_pub.pem,也就是私鑰和公鑰,請妥善保存這兩個文件,如果私鑰丟失,你得用戶將再也無法自動通過已安裝的程序來獲得更新的更新。

            15: 建立一個 App Cast Feed文件

            Sparkle的運作機理其實非常簡潔,本地應用程序Info.plist中含有一個URL,此URL指向一個在你網站上的App Cast Feed XML文件。當你發布更新的時候,上傳新的app到你的網站,更新此app cast xml feed。這樣,客戶端程序在運行檢查更新時,會根據Info Plist中的URL找到并Parse此文件,跟本地軟件版本進行比對。如果發現更新,則提示用戶。這就是App Cast XML Feed文件的作用。

            在步驟14中提到的Extras文件夾下,有一個App Cast XML Feed文件的模版:

             

            http://you.com/app/2.0.html

            Wed, 09 Jan 2006 19:20:11 +0000

            http://you.com/app/1.5.html

            Wed, 01 Jan 2006 12:20:11 +0000
            <!-- Now here's an example of a version with a weird internal version number (like an SVN revision) but a human-readable external one. -->
            http://you.com/app/1.4.html

            Wed, 25 Dec 2005 12:20:11 +0000

            我們可以看出,這其實是一個標準的RSS Feed格式的XML文件。我們只要修改相應的項目即可。

            下面我們就來一步步的演示如何使用Sparkle為你的程序加入更新支持。

            16: 我們首先在本地搭建一個可用于測試軟件更新的網站。打開Mac OS X系統偏好設置(System Preferences), 找到共享(Sharing),開啟Web共享(Web Sharing),并通過點擊圖中所示URL測試Web共享是否成功開啟。http://10.0.1.2/~buick 你的顯示可能與此不同,,,,

            wpid-wpid-websharing-2010-09-10-16-11-2010-09-10-16-11.png
            17: 打開你的XCode中 TestSparkle 工程,編輯 TestSparkle-Info.plist,加入兩個屬性,SUPublicDSAKeyFile 和 SUFeedURL

            wpid-wpid-info.plist-2010-09-10-16-11-2010-09-10-16-11.png

            其中,SUFeedURL 將是指向一個 App Cast XML Fee 的 URL,比如我的測試地址是 http://10.0.1.2/~buick/testsparkleappcast.xml ,SUPublicDSAKeyFile 指向公鑰,我們把剛才步驟14中生成的 dsa_pub.pem 加入到工程的Resources中,并在 TestSparkle-Info.plist 中指定此公鑰的名稱,,,,那么現在的TestSparkle-Info.plist應該是這樣

            整個配置完成,我們現在來構建一個TestSparkle.app的1.0版本,點擊Build and Run

            wpid-wpid-TestSparkle-2010-09-10-16-11-2010-09-10-16-11.png
            啟動TestSparkle.app, 在TestSparkle菜單下,確認Check for Updates…按鈕處于可用狀態,如果是灰色不可點擊,則返回Interface Builder修改。

            wpid-wpid-checkforupdates-2010-09-10-16-11-2010-09-10-16-11.png

            將此 TestSparkle.app 1.0 版本拷貝到別處備用。然后返回XCode,將應用程序版本改為1.1,然后構建工程。將TestSparkle.app 的1.1版本打包成zip文件,改名為TestSparkle_1.1.zip

            將 dsa_priv.pem (私鑰) 和 TestSparkle_1.1.zip 拷貝到 Extras下的Signing Tool文件夾中,

            wpid-wpid-signing-2010-09-10-16-11-2010-09-10-16-11.png

            打開終端進入到此文件夾,執行:

            ruby sign_update.rb TestSparkle_1.1.zip dsa_priv.pem

            wpid-wpid-sign-2010-09-10-16-11-2010-09-10-16-11.png
            便可得到升級包的簽名,MCwCFDZsrVGB+PewvxioJcvptkqchXi3AhQOZDJ4UukRM2/bYmZzzbHTxM2kpA==

            用文本編輯器創建一個xml文件(UTF-8 編碼),內容如下:

            http://10.0.1.2/~buick          The latest TestSparkle updates from localhost, more hot features and sweeties
            en

            Fri, 10 Sept 2010 0:00:00 +0300             http://10.0.1.2/~buick

            注意(由于本網站HTML的設置問題,如果你直接拷貝以上XML Feed文件到你本地測試可能會出編碼問題導致XML Parse失敗,請到本文最后下載此文件,以及工程壓縮包)。

            把此XML另存為 testsparkleappcast.xml

            熟悉RSS Feed的讀者可能很容易理解此文件,,如果我們在瀏覽器中直接訪問此URL,我們會看到

            wpid-wpid-feed-2010-09-10-16-11-2010-09-10-16-11.png

            而我們要關注的只是這兩段:

            這段指定的URL是一個介紹頁面,如果你希望在更新提示窗口中出現一個介紹新版本的頁面(或者說release notes),則使用此URL定向到你網站上的新版本介紹頁面。

            Sparkle非常貼心的為大家提供了一個模版,在Extras/Release Notes Templates 文件夾下可找到

            enclosure sparkle:version=“1.1” sparkle:dsaSignature=“MCwCFDZsrVGB+PewvxioJcvptkqchXi3AhQOZDJ4UukRM2/bYmZzzbHTxM2kpA==“ url=“http://10.0.1.2/~buick/TestSparkle_1.1.zip” length=“436264” type=“application/octet-stream”/>

            這段是實現Sparkle Update的關鍵,

            sparkle:version=“1.1” 是指當前更新包版本號,客戶端程序就是根據這個版本號來和本地APP進行比對,如果發現不同則提示更新。

            sparkle:dsaSignature=“MCwCFDZsrVGB+PewvxioJcvptkqchXi3AhQOZDJ4UukRM2/bYmZzzbHTxM2kpA==“ 這個就是我們剛才為更新包生成的數字簽名

            url=“http://10.0.1.2/~buick/TestSparkle_1.1.zip” 指向更新包下載地址

            length=“436264” 指更新包的大小,上傳上去前用 終端 ls -al 命令可查看

            type=“application/octet-stream” 是一個想對固定的值,一般不用修改。

            現在把testsparkleappcast.xml 和 TestSparkle_1.1.zip 拷貝到

            你的用戶主目錄/Sites 下 (~/Sites,具體路徑依你個人配置而定)

            wpid-wpid-path-2010-09-10-16-11-2010-09-10-16-11.png
            然后在瀏覽器敲入 http://10.0.1.2/~buick/testsparkleappcast.xml

            如果能夠看到類似網頁,,,說明一切正常。

            下面找到我們剛才保存的TestSparkle.app 1.0版本,運行并點擊 Check for Updates… 如果一切正常,你可以看到

            wpid-update1-2010-09-10-16-11.png

            點擊Install Update,如果更新成功,即可顯示:

            wpid-complee-2010-09-10-16-11.png

            然后再次點擊Check for Updates, 你會看到

            wpid-latest-2010-09-10-16-11.png

            最后希望你與Sparkle合作愉快。

            點擊此處下載本次工程源代碼和示例XML Feed文件,另外,安裝包里面還帶有一個Sparkle的簡體中文包,將它放入你的Sparkle.framework/Resources下即可。

            国产—久久香蕉国产线看观看 | 四虎国产精品成人免费久久| 91性高湖久久久久| 大香网伊人久久综合网2020| 久久久久亚洲精品天堂久久久久久| 亚洲午夜久久久| 亚洲∧v久久久无码精品| 久久婷婷成人综合色综合| 久久国产精品一区二区| 亚洲美日韩Av中文字幕无码久久久妻妇 | 一本大道久久香蕉成人网| 一本一本久久aa综合精品| 女人香蕉久久**毛片精品| 看全色黄大色大片免费久久久| 亚洲精品乱码久久久久久| 一本色道久久88加勒比—综合| 麻豆av久久av盛宴av| 久久免费高清视频| 亚洲欧洲日产国码无码久久99| 青青草原综合久久| 久久亚洲美女精品国产精品| 久久无码人妻精品一区二区三区| 亚洲av伊人久久综合密臀性色| 久久久WWW成人| 51久久夜色精品国产| 人妻少妇久久中文字幕一区二区| 久久电影网| 国产亚洲欧美成人久久片| 国产香蕉久久精品综合网| 99久久婷婷国产综合精品草原| 久久亚洲AV成人无码国产| 思思久久99热只有频精品66| 狠狠综合久久综合中文88| 囯产极品美女高潮无套久久久 | 久久伊人精品青青草原高清| 亚洲国产精品无码久久久蜜芽 | 久久婷婷成人综合色综合| 久久久久亚洲AV无码观看| 亚洲人成网站999久久久综合 | 久久婷婷色综合一区二区| 亚洲国产成人久久综合区|