Python實現iOS APP 自動化打包

一 各種打包方法簡介:

  1. Xcode 打包:
    XCode -- > Product --> Archive 常規(guī)打包方式,需要提前配置好簽名信息.

2.提取工程目錄Products下的.app文件進行包裝打包:

3.使用命令行工具xcodebuild進行打包.

4.python編寫自動化打包腳本,運行腳本實現一鍵打包部署.

二 Xcode 打包:

略.... 你懂得

三 .app文件進行包裝打包:

具體步驟如下:

1. XCode -- >Build 
2.新建文件夾,命名Payload.
3.提取Products下的.app文件,放進Payload文件夾中,然后把Payload進行壓縮得到Payload.zip.
4.將Payload.zip名字改為: 工程名.zip
5.工程名.zip的后綴名改為工程名.ipa

上圖:


屏幕快照 2019-04-03 下午4.07.55.png
屏幕快照 2019-04-03 下午4.09.39.png
屏幕快照 2019-04-03 下午4.13.08.png

四. xcodebuild命令行打包:

具體操作如下:

  1. cd到工程目錄下
  2. $ xcodebuild clean -workspace xxxx.xcworkspace -scheme xxxx -configuration Release
1.將其中`xxxx`替換成你的工程名.
2. `Release`是編譯模式,分為`Release`和`Debug`,根據需要自行配置.
  1. $ xcodebuild archive -workspace xxxx.xcworkspace -scheme xxxx -configuration Release -archivePath /Users/pactepacterara/Desktops/xxxx
1.xxxx是工程名
2./Users/pactepacterara/Desktops/是archive文件的輸出路徑,我這里默認放桌面,可自行配置,后面跟項目名.
  1. $ xcodebuild -exportArchive -archivePath /Users/pactepacterara/Desktop/xxxx.xcarchive -exportPath /Users/pactepacterara/Desktop -exportOptionsPlist /Users/pactepacterara/Desktop/ExportOptions.plist
1.  /Users/pactepacterara/Desktop/ExportOptions.plist這是ExportOptions.plist文件的路徑.
2. ExportOptions.plist文件需要你使用Xcode先手動構建一次篙程,然后將ExportOptions.plist文件放到指定路徑,我是放桌面.

執(zhí)行上述操作,即可完成打包.

五. python自動化打包

編寫python文件,使用Xcode就可以
直接上代碼:


#!/usr/bin/env python
#coding=utf-8
#環(huán)境: UAT&SIT

import os
import requests
import webbrowser
import subprocess
import time
import smtplib

# 路徑信息
project_name     = 'AutoPackageDemo'                 # 項目名稱
project_path     = '/Users/pactepacterara/iOS'       # 項目路徑
export_directory = '/Users/pactepacterara/Desktop'   # 輸出的路徑
exporrt_folder   = 'auto_archive'                    # 輸出的文件夾


# 蒲公英app地址、USER_KEY、API_KEY,具體見蒲公英官網: 賬戶設置-->API信息
ipa_download_url = 'https://www.pgyer.com/manager/dashboard/app/xxxxxxxxxxxxxxxx'
USER_KEY         = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
API_KEY          = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'


class AutoArchive(object):
    
    def __init__(self):
        pass
    
    def clean(self):
        
        print("\n\n===========開始clean操作===========")
        start = time.time()
        clean_opt = 'xcodebuild clean -workspace %s/%s.xcworkspace -scheme %s -configuration Release' % (project_path, project_name, project_name)
        clean_opt_run = subprocess.Popen(clean_opt, shell=True)
        clean_opt_run.wait()
        end = time.time()

        # clean 結果
        clean_result_code = clean_opt_run.returncode
        if clean_result_code != 0:
            print("===========clean失敗,用時:%.2f秒===========" % (end - start))
        else:
            print("===========clean成功,用時:%.2f秒===========" % (end - start))
            self.archive()

    def archive(self):
        print("\n\n===========開始archive操作===========")

        subprocess.call(['rm', '-rf', '%s/%s' % (export_directory, exporrt_folder)])
        time.sleep(1)
        subprocess.call(['mkdir', '-p', '%s/%s' % (export_directory, exporrt_folder)])
        time.sleep(1)
     
        start = time.time()
        archive_opt = 'xcodebuild archive -workspace %s/%s.xcworkspace -scheme %s -configuration Release -archivePath %s/%s' %(project_path, project_name, project_name, export_directory, exporrt_folder)
        archive_opt_run = subprocess.Popen(archive_opt, shell=True)
        archive_opt_run.wait()
        end = time.time()
        
        # archive 結果
        archive_result_code = archive_opt_run.returncode
        if archive_result_code != 0:
           print("===========archive失敗,用時:%.2f秒===========" % (end - start))
        else:
           print("===========archive成功,用時:%.2f秒===========" % (end - start))
        
        # 導出IPA
        self.export()

    def export(self):
        print("\n\n===========開始export操作===========")
        start = time.time()
        export_opt = 'xcodebuild -exportArchive -archivePath %s/%s.xcarchive -exportPath %s/%s -exportOptionsPlist %s/ExportOptions.plist' % ( export_directory,exporrt_folder,export_directory, exporrt_folder,export_directory)
        export_opt_run = subprocess.Popen(export_opt, shell=True)
        export_opt_run.wait()
        end = time.time()
        
        # ipa導出結果
        export_result_code = export_opt_run.returncode
        if export_result_code != 0:
            print("===========導出IPA失敗,用時:%.2f秒===========" % (end - start))
        else:
            print("===========導出IPA成功,用時:%.2f秒===========" % (end - start))
        
        # 刪除archive.xcarchive文件
        subprocess.call(['rm', '-rf', '%s/%s.xcarchive' % (export_directory, exporrt_folder)])
        self.upload('%s/%s/ZBank.ipa' % (export_directory, exporrt_folder))

    def upload(self, ipa_path):
        
        print("\n\n===========開始上傳蒲公英操作===========")
        if ipa_path:
            
            # 蒲公英操作API
            # https://www.pgyer.com/doc/api
            url = 'http://www.pgyer.com/apiv1/app/upload'
            data = {
                    'uKey': USER_KEY,
                    '_api_key': API_KEY,
                    'installType': '2',
                    'password':pwd,
                    'updateDescription': description
            }
            files = {'file': open(ipa_path, 'rb')}
            r = requests.post(url, data=data, files=files)
            if r.status_code == 200:
                self.open_browser(self)
            
        else:
            print("\n\n===========沒有找到對應的ipa===========")
            return
    
    @staticmethod
        # 上傳成功,通過瀏覽器打開蒲公英網站
    def open_browser(self):
        webbrowser.open(ipa_download_url, new=1, autoraise=True)



if __name__ == '__main__':
    description = input("請輸入更新的日志描述:")
    pwd=input("請輸入蒲公英安裝密碼:")
    archive = AutoArchive()
    archive.clean()
   

終端執(zhí)行命令:
$ python /Users/pactepacterara/Desktop/HuiAotuArchievePackage_生產.py

屏幕快照 2019-04-03 下午5.41.08.png

注意事項:
1.問題場景:
當現有描述文件發(fā)生改變,比如在開發(fā)者中心維護了新的測試設備,更新-->下載--> 安裝描述文件以后,繼續(xù)使用先前配置好的python進行打包時,發(fā)現新注冊的測試設備并沒有添加到描述中,自然也就無法正確安裝,對ipa文件進行解包發(fā)現描述文件中確實不包含新注冊的設備.
2.解決辦法:更新描述文件后,重新使用xcode成功打包一次后,在使用python打包
3.原因:從蘋果開發(fā)者中心網站下載的描述文件并非原封不動的打進我們的app包里面的,而是經過了xcode的二次包裝,其中簽名時生成一個,導出ipa時生成一個.

當我們選擇先清空xcode本地安裝的描述文件,再安裝最新的描述文件,再運行python自動打包腳本時,會在導出ipa步驟時報錯,具體報錯為找不到對應的描述文件.

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末喳坠,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖吼和,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件一屋,死亡現場離奇詭異窘疮,居然都是意外死亡,警方通過查閱死者的電腦和手機冀墨,發(fā)現死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門闸衫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人诽嘉,你說我怎么就攤上這事蔚出〉芮蹋” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵骄酗,是天一觀的道長稀余。 經常有香客問我,道長酥筝,這世上最難降的妖魔是什么滚躯? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮嘿歌,結果婚禮上掸掏,老公的妹妹穿的比我還像新娘。我一直安慰自己宙帝,他們只是感情好丧凤,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著步脓,像睡著了一般愿待。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上靴患,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天仍侥,我揣著相機與錄音,去河邊找鬼鸳君。 笑死农渊,一個胖子當著我的面吹牛,可吹牛的內容都是我干的或颊。 我是一名探鬼主播砸紊,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼囱挑!你這毒婦竟也來了醉顽?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤平挑,失蹤者是張志新(化名)和其女友劉穎游添,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體通熄,經...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡否淤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了棠隐。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡檐嚣,死狀恐怖助泽,靈堂內的尸體忽然破棺而出啰扛,到底是詐尸還是另有隱情,我是刑警寧澤嗡贺,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布隐解,位于F島的核電站,受9級特大地震影響诫睬,放射性物質發(fā)生泄漏煞茫。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一摄凡、第九天 我趴在偏房一處隱蔽的房頂上張望续徽。 院中可真熱鬧,春花似錦亲澡、人聲如沸钦扭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽客情。三九已至,卻和暖如春癞己,著一層夾襖步出監(jiān)牢的瞬間膀斋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工痹雅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留仰担,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓练慕,卻偏偏與公主長得像惰匙,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子铃将,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內容