連接地址:http://blog.csdn.net/mad1989/article/details/8167529html
最近項目到了最後的階段,測試完一切ok後,準備打包以及提交,不料看到網上衆教程,好多都是老版本的,如今IDE實現方式改了,那些方法好多都找不到,繞了一大圈,才搞明白流程,如今記錄下來,以便朋友們查閱。ios
開發環境:xcode4.4.1web
iphonesdk:5.1.1xcode
開發機器:macBookAir安全
真機部署測試:apple我的開發者ID服務器
不管是ios7或是如今的xcode5,雖然有些樣式改變了,可是實際上的流程仍是這個樣子,因此供您參考,少走彎路,仍是有必定的做用。app
嚮導:iphone
必備IDP證書和distribution證書(第一個證書是真機部署測試時用到的,後者證書是發佈時須要用到的,缺一不可)。ide
我就說說接下來應該作的流程。在你保證擁有以上兩個證書的前提下,距離app提交審覈,已經剩下兩大步了:1,ituneconnect建立app,填寫項目詳細信息。2,xcode打包驗證經過,提交項目。好的,我就開始說重點了,童鞋們跟着個人流程走,保證不會迷糊和出錯。
1.預先準備
在你開始將程序提交到App Store以前,你須要有一個App ID,一個有效的發佈證書,以及一個有效的Provisioning profile。下面來看看它們各自的做用。
Step 1: App ID(應用ID)
App ID是識別不一樣應用程序的惟一標示符。每一個app都須要一個App ID或者app標識。目前有兩種類型的App標識:一個是精確的App ID(explicit App ID),一個是通配符App ID(wildcard App ID)。使用通配符的App ID能夠用來構建和安裝多個程序。儘管通配符App ID很是方便,可是一個精確的App ID也是須要的,尤爲是當App使用iCloud 或者使用其餘iOS功能的時候,好比Game Center、Push Notifications或者IAP。
若是你不肯定什麼樣的App ID適合你的項目,我推薦你讀下蘋果關於這一主題的文檔:Technical Note QA1713。
Step 2: Distribution Certificate(發佈證書)
iOS應用都有一個安全證書用於驗證開發者身份和簽名。爲了能夠向App Store提交app,你須要建立一個iOS provisioning profile 。首先須要建立一個distribution certificate(發佈證書),過程相似於建立一個development certificate(開發證書)。若是你已經在實體設備上測試你的App,那麼你對建立development certificate就已經很熟悉了。
若是對此不熟悉,我建議你讀下蘋果關於signing certificates和provisioning profiles的詳細指導。
Step 3: Provisioning Profile(配置文件)
一旦你建立了App ID和distribution certificate,你能夠建立一個iOS provisioning profile以方便在App Store中銷售你的App。不過,你不能使用和ad hoc distribution相同的provisioning profile。你須要爲App Store分銷建立一個單獨的provisioning profile,若是你使用通配符App ID,那麼你的多個app就可使用相同的provisioning profile。
Step 4: Build Settings(生成設置)
配置App ID、distribution certificate 和provisioning profile已經完成,是時候配置Xcode中target的build settings了。在Xcode Project Navigator的targets列表中選擇一個target,打開頂部的Build Settings選項,而後更新一下Code Signing來跟以前建立的distribution provisioning profile相匹配。最近添加的provisioning profiles有時候不會立馬就在build settings的Code Signing中看到,重啓一下Xcode就能夠解決這個問題。
Step 5: Deployment Target(部署目標)
很是有必要說下deployment target,Xcode中每一個target都有一個deployment target,它能夠指出app能夠運行的最小版本。不過,一旦應用在App Store中生效,再去修改deployment target,你要考慮到必定後果。若是你在更新app的時候提升了deployment target,可是已經購買應用的用戶並無遇到新的deployment target,那麼應用就不能在用戶的移動設備上運行。若是用戶經過iTunes (不是設備)下載了一個更新過的app,而後替代了設備上原先的版本,最後卻發現新版本不能在設備上運行,這確實是個問題。
(2) 對於一款新app,我常常會把deployment target設置爲最近發佈的系統版本。由於新iOS版本發佈後,滲透率的增加速度是使人難以置信的。不少人認爲提升deployment target會失去大部分市場,這個說法並不許確,好比iOS 6,iOS 6發佈後一個月,超過60%的設備已經進行了更新。但對Android而言,就是另一回事了,Android用戶並不會像iOS用戶那樣熱衷於更新操做系統版本。
【以上簡而言之,最好從項目設計時,就決定是否考慮兼容低版本用戶,支持的話,寫代碼時使用ios新特性時最好作一下判斷,if是老版本if是新版本】
2. Assets(資源包)
Step 1: Icons(圖標)
Icon是App中不可分割的一部分,你要確保icon尺寸不會出現差錯。
iTunes Artwork: 1024px x 1024px (required)
iPad/iPad Mini: 72px x 72px and 114px x 114px (required)
iPhone/iPod Touch: 57px x 57px and 114px x 114px (required)
Search Icon: 29px x 29px and 58px x 58px (optional)
Settings Application: 50px x 50px and 100px x 100px (optional)
Step 2: 屏幕截圖
屏幕截圖的做用不言而喻,你能夠爲每一個app上傳5張截圖,雖然至少須要上傳一張,可能不多有人會只上傳一張圖片。另外,你還須要分別爲iPhone/iPod Touch和iPad/iPad Mini準備不一樣的屏幕截圖。這也是不小的工做量,但卻能展現應用的另外一面。Shiny Development開發的一款售價6.99美圓的Mac軟件Status Magic能夠爲你節省很多時間。Status Magic能夠幫你把狀態欄放在截圖的正確位置。
屏幕截圖和icon是應用給用戶的第一感受,直接關係到用戶會不會購買。不過,你所上傳的屏幕截圖也不必定非得是實際的截圖,看看Where’s My Water? 截圖能夠經過使用此策略,更具吸引力和說服力。
Step 3: 元數據
在提交應用以前,要管理好app的元數據,包括1應用名稱、2版本號、3主要類別,4簡潔的描述,5關鍵詞,6.支持URL。若是你須要更新應用,你還要提供新增長的版本內容。
若是你的應用須要註冊【打開APP須要登陸,好比飛信】,你還得向蘋果提供一個測試帳戶或者demo帳戶,這樣審覈人員就能很快進入app,而不用再註冊帳號。
3. 提交準備
Xcode 4之後,開發者提交應用的過程就簡單多了,能夠直接使用Xcode進行提交。首先在iTunes Connect中建立app,訪問iTunes Connect,使用你的iOS開發者帳號登錄,點擊右邊的「Manage Your Apps」,點擊左上角的「Add New App」,選擇「iOS App」,而後完成表格。
(注意,建立時填的APP就是你開發的項目,名稱和ID必定要相同)。https://itunesconnect.apple.com
點擊進入
左上角,添加一個APP,若是你的開發帳號以前已經提交過app,下面就會列出來。
第一個頁面,選擇語言,應用名稱,skunumber,bundleID(會讓你選擇本身建立項目的APPID)。
SKU Number是一個用來識別app的特殊字符串。我常用app的bundle identifier。最下邊是app的Bundle ID,你能夠從下來菜單中選擇通配符App ID或者準確的App ID。
這個頁面是選擇app上線的日期(由於apple還須要審覈,通常都是推遲幾天),售價,以及是否支援教育機構之類的。
以上頁面是寫版本號,公司名稱,軟件首類別,次類別(注意兩個類別不得重複,不然不會經過),以及評級劃分。
以上是軟件的內容描述,關鍵字,技術支持url,以及下面的技術負責人的名字,姓,email,手機號碼,這些都很簡單,大家都懂的。
----------------------------------------------------------------------------------------------------------------------------------------
接下來是選擇APPicon 一張1024X1024的軟件圖標,讓ui作吧,我也不曉得軟件的圖標爲啥要作這麼大;
繼續上傳5張軟件的截圖,要挑選最重要的圖片展現,大小是640x960,xcode上集成了截圖功能,則是打開window-organizer視圖窗口,點擊本身的手機標籤頁下的screenshot,就能夠截圖了,尺寸正好,很方便的噢親。
有常規的iphone4,iphone5,以及ipad各個add的入口,有的話就上傳,沒有的話就空着
因爲上傳時我忘記截圖了,因此次頁面就不能展現給你們了,不過很簡單的一看就懂。
完過後檢查無誤,點擊提交。
----------------------------------------------------------------------------------------------------------------------------------------
好了,走到這一步,基本上算是完成了一個app的建立,這裏列舉了你的skunumber,bundleID,appleID,隨處可見的edit點擊進入能夠修改剛纔提交的信息,看到紅色圈住的狀態了:prepare for upload 千萬不要認爲此時工做完成了,還差一步,若是此時你關閉了頁面,準備最後一步,你會發現到時會出錯的。我就由於這個繞了半天。
點擊坐下的view Details進入後的頁面回會是此軟件的一個詳細列表展現了軟件的名稱,描述,軟件截圖,技術聯繫人信息,等。看完無誤後,必定要點擊右下角(或右上角)的按鈕(Ready to Upload Binary),只有點了這個按鈕,纔會改變當前status的狀態爲:waiting for upload。
【注意:若是是Ready for upload 狀態,在xcode下打包提交應用,會有:No suitable application records were found.
Please make sure that you have set up a record for this application on iTunes Connect.的錯誤提示。】
此時,若是你的首頁status變成了:waiting for upload 那麼恭喜你,此步順利經過,剩下最後了。(注意如上截圖,點擊continue,完成了網頁的全部工做)。
4.xcode上操做:設置證書,build打包,提交項目。
打開xcode,首先確保你配置好了distribution證書,看我以下截圖。
確保debug和release都是選中咱們申請好的distribution證書。到了次步驟,有的教程說建立一個新的codesigning identity 我也嘗試建立了,不過這裏不推薦新手建立,由於使用release照樣能夠打包,創新新的identity認爲會讓新手更暈菜。(如上截圖)
5. 上傳二進制文件
爲了上傳程序,須要爲程序建立一個archive。你只能在一臺真實設備上建立一個archive。若是你在active scheme中選擇了iOS Simulator,那麼在Xcode的Product菜單中Archive選項是灰色不可選的。鏈接一臺iOS設備到Mac機器上,而後在active scheme中選擇這臺設備,而後選擇Xcode中Product菜單裏面的Archive。
選中項目名稱,設備改成ios Device(咱們不須要使用模擬器或真機來build打包),而後選擇 edit Scheme(如上截圖)
此界面頂部要肯定選中的是你的項目名稱和iosDivice設備;左邊欄選中Archive,右邊的內容爲以上視圖。點擊ok。(如上截圖)
此時大功告成,在xcode-Product菜單選中build一下(快捷鍵command+B),而後再點擊Archive。(如上截圖)兩個都成功的話,就繼續下一步,不然請檢查兩個證書的配置。
若是一切正常的話,如今你會得到一個archive,而且Xcode的Organizer會自動打開,並顯示出剛剛生成的archive。在列表中選中archive,而後點擊右邊的「Distribute」按鈕。在顯示出來的畫面中,選擇「Submit to the iOS App Store」。而後輸入你的iOS開發者帳號進行認證。接着選擇Application 和Code Signing Identity。
應用程序的二進制文件會上傳到蘋果的服務器中——在這個過程當中,你的程序一樣須要被驗證。若是在驗證過程當中遇到了錯誤,程序的提交流程就會失敗。驗證處理很是有用,若是程序中有一些錯誤,蘋果的 App Store評審團會告訴你具體緣由。
Archive成功後,就會在Organizer界面生成咱們的應用,進入後能夠看到軟件詳細信息,這個identifier必定要和咱們第三步網頁上的一致。
1111》點擊右邊的第一步1,驗證此項目。(如上截圖);(點擊進入後輸入apple開發者帳號和密碼,下一步)
帳號經過後,會讓你選中application 和distribution證書,依次選擇,next(如上截圖)。
驗證經過後,會有如上界面展現,ok,恭喜你。
2222》接下來,咱們繼續第二步,提交項目(Distribute)
若是你的項目是須要提交到AppStore,則選擇第一個,next(如上截圖)
若是是如上提示,那麼恭喜你,咱們終於完成了這shit的流程,點擊finish!!我不再想看到這些了,close Xcode。(如上截圖)
----------------------------------------------------------------------------------------------------------------------------------------
咱們再次打開itunesconnect,登陸進入-會發現當前項目的status終於變了
Waiting for Review~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~這不就是咱們最想要的結果麼!!!終於提交完成了,apple審覈時間大約是1-2周,若是經過的話,就會按照咱們寫的時間上架,若是未經過,會發email~~注意查收噢。
好了,接下來講一下,如何在有IDP證書,開發者帳號的狀況下,經過正規途徑,導出ipa,安裝在任意iphone手機中(親測越獄手機)
當咱們在上幾步,打包build的時候,觀看你項目的Products文件夾下,已經生成了真實的app,不過這個還不是咱們真正想要的.ipa文件。(如上截圖)選中Product下的app,右鍵show in Finder,此時打開咱們的itunes,拖動軟件到itunes下。
此時,咱們的軟件就拖到了itunes中了,但是發現沒有軟件圖標啊,不用怕,這是很正常的。右鍵軟件,選擇在Finder中顯示(如上截圖)
此時,眼前這個軟件,就是咱們想要的ipa啦。我親測安裝到越獄後的手機,一點問題都沒有(不用擔憂證書的問題)【注意:越獄手機的版本必定要高於軟件的版本要求】
目前尚未測試未越獄的手機,不過我想應該沒法安裝,由於apple的審查機制是很嚴格的,必須安裝在有描述文件Provision的手機中內(這一點在真機部署測試時就已經體現出來了)
2014年5月30日插播
若是您都看到了這裏,我真的佩服您能忍受我如此繁瑣的措辭,由於時間緣由,寫一篇博客並非很容易,因此有些語言或是排版組織的不是很好,1年過來了,如今我終於理解整個調試以及發佈以及多人開發的流程,若是您如今也是朦朧狀態,感受apple的機制好麻煩,或是在多人開發時遇到了:Valid signing identity not found 不妨建議您看我另外一篇文章,文章最後介紹了Certificate、App ID、Devices、Provisioning Profiles之間區別和聯繫,相信您看完後必定會恍然大悟!
Valid signing identity not found解決辦法(原有IDP私鑰丟失)及Certificate、App ID、Devices、Provisioning Profiles之間區別http://blog.csdn.net/mad1989/article/details/8699147
好了,謝謝各位看到這裏,說的有些囉嗦,可是若是你按照此步驟,走完流程,就會悟出其原理。至少不是看到一教程,又看到另外一教程,都不同,乾着急。
有什麼問題能夠給我留言,我看到後會儘可能幫助你們解決,一塊兒學習,成長。
贈送傳送門一個:http://www.cocoachina.com/special/market.html
20121109
mryang
2013年1月14日最新更新 :新版本提交審覈
當咱們通過重重關卡,新項目終於在AppStore 上線以後,就會接踵而來遇到維護的問題,那麼新版本提交,就沒有這麼複雜了,若是以上的教程你都理解了,新版本也就那麼幾個須要注意的地方,聽我慢慢道來。
1,首先須要修改代碼,就是說,你要有更新的內容,好比功能,好比bug(貌似是廢話)
2,當肯定一切都ok以後,須要設置項目的version和build號,新版本
Version是顯示對外的版本號,(itunesconect和Appstore用戶能夠看到),而build別人看不到,只有開發者本身才能看到,至關於內部版本號。【更新版本的時候,也要高於以前的build號】
3,登陸ituneconnect網站,在項目右側,點擊add new version ,彈出提示輸入版本名稱和更新內容,完過後點save。
4,在網站上詳細審查一下新的版本名稱和更新內容,還有是否有須要替換的截圖,肯定無誤後點右上角的ready to binary ,到此網站的設置完畢。接下來就是xcode提交新項目了。【此設置有一個須要注意的提示,以下截圖】
讓你選擇是審覈經過後自動更新到應用商店,或是本身手動控制更新,很人性化。
5,Xcode設置 codesign identity 爲發佈的證書,Divice選則iosDevice ,而後build 而後archive,跟上邊第一次發佈時同樣。
6,打開organizer界面的archive標籤頁,檢查無誤後,先驗證Validate後Distribute。
等待完畢後,若是沒有什麼問題,刷新itunescnnet網站吧,你新提交的項目狀態變成了:Waiting For Review
20120114
**********************************打包上傳時錯誤彙總《持續更新》**********************************
它是說,你的簽名不對,打包發佈APP時,必定要使用Release模式,並把證書選擇爲本身的Distribution發佈證書。
關於Validate Built Product設置YES或NO
有時打包遇到錯誤,網上都說,在Target設置----->build------>Validate Built Product選項去掉或設置爲NO就能夠了。從網上搜了一下Validate Built Product的含義,大概意思是說開啓內置驗證,好比apple規定的一些icon大小是57X57,而你的icon尺寸不是這個,就會致使發佈失敗。
這個是說,debug的證書選擇錯誤了,解決辦法:
TARGETS --> Build Settings --> Code Signing --> Code Signing Identity設置爲 iPhone Developer
這樣就ok啦。
這個警告,網上遇到的人不少,可是衆說紛紜,貌似沒有一個權威的解決辦法,
首先要養成一個查閱官方文檔的習慣:https://developer.apple.com/ios/manage/distribution/index.action
要明白真機調試和發佈應用的幾個步驟,不能連APP還沒建立,就直接想用Xcode打包發佈啊!還有要明白debug和release的做用和區別。
這個警告,個人理解是:
前提確認Xcode是近期的版本,工程的SDK也至少要是經常使用的。APPID正確,真機調試證書和Distribution證書都對應於當前Xcode設置。
首先檢查你的Project的info是否正確了,還有就是Target設置是否正確..
而後注意不要使用模擬器build,要選擇Device,去Edit scheme裏查看archive的時候,是否是使用的release!
若是都不行就刪除鑰匙串裏的相關文件,從新去ADP裏申請再下載!
20130510
上傳時出錯:failed to get the task for process 624
This error happens when you have set Distribution Provisioning profile in code signing. Change it to Developer Provisioning Profile, then it will work. Worked for me for Xcode SDK 4.5.
把你的code sign由Distribution改爲Developer.就這麼簡單.
上傳時出錯:CFbundleVersion
這個錯誤是說,咱們項目info.plist文件中的bundleVersion弄錯了,這個屬性須要int類型的數值,改爲以下圖所示就能夠了。
20140111