• <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下即可。

            日本亚洲色大成网站WWW久久| 久久国产高清一区二区三区| 久久久国产精华液| 久久无码高潮喷水| 无码超乳爆乳中文字幕久久| 无码国内精品久久人妻| 国产L精品国产亚洲区久久| 最新久久免费视频| 国产精品久久久久国产A级| 久久久久久无码国产精品中文字幕 | 久久久久亚洲av综合波多野结衣 | 人妻少妇久久中文字幕一区二区| 色欲久久久天天天综合网| 77777亚洲午夜久久多喷| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 国产精品久久久久久| 一级做a爰片久久毛片毛片| 国产精品久久久久AV福利动漫 | 69久久精品无码一区二区| 国产精品成人99久久久久| 久久精品欧美日韩精品| 欧美日韩中文字幕久久久不卡| 精品熟女少妇a∨免费久久| 久久久久久免费视频| 久久精品国产福利国产琪琪| 久久国产色AV免费观看| 久久久精品国产免大香伊| 久久天天躁狠狠躁夜夜av浪潮 | 国产亚洲精久久久久久无码 | 精品国产一区二区三区久久| 久久久久久久久久久精品尤物| 久久AⅤ人妻少妇嫩草影院| 久久综合久久综合九色| 国产精品一区二区久久不卡| 色综合久久久久无码专区| 久久久久久久精品妇女99| 亚洲人成无码久久电影网站| 久久久久亚洲av成人无码电影 | 色88久久久久高潮综合影院| 伊人久久大香线蕉AV色婷婷色| 久久这里的只有是精品23|