iOS自動パッケージ生成ipa

8034 ワード

先日iOSグループでipaを自動的にパッケージ化したpythonファイルを共有している人がいたのを見て、興味を持っていましたが、当時は仕事が忙しくて気にしていませんでした.ちょうど今日は時間があったので、どうやって遊ぶかを研究しました.中に注意しなければならないところがあります.ここで共有してください.pythonの文章の一番下に貼ってあります.
pythonファイルの場所が正しいことを確認します
  • pythonファイルをプロジェクトのエンジニアリングファイルのディレクトリの下に置きます.
  • 端末を開き、エンジニアリングファイルのディレクトリの下に入ります.

  • pythonファイルの実行
    コマンドは次のとおりです.
    python autobuild.py -p Gomefxs.xcodeproj -s Gomefxs -t Gomefxs -o  ~/Desktop/Gomefxs.ipa
    

    ここで工事名を正しく書くには、工事書類がxcworkspaceでは、コマンドの-pを-wに変更する必要があります.pythonコードには次のコードがあります.
    parser.add_option("-w", "--workspace", help="Build the workspace name.xcworkspace.", metavar="name.xcworkspace")
    parser.add_option("-p", "--project", help="Build the project name.xcodeproj.", metavar="name.xcodeproj")
    

    コンピュータのpythonにrequestsがあることを確認します
    私が思った時ipaファイルがもうすぐデスクトップに表示されるとき、端末に私が見たいものが現れて、間違いを報告しました.
    NO module named requests
    

    エラーを報告するコードは3行目で、pythonコードの3行目は次のようになります.
    import requests
    

    pythonの完全な知識の備蓄である私も、とっくに世間にこんな言葉が伝わっていると聞いていた.import大法がいい.しかし残念なことに、上の端末の情報はもう言っています.私はこのrequestsというものをimportしていません(pythonを知っている友达に聞いてみましたが、これはモジュールと呼ばれています).調べてみると、端末に直接モジュールをインストールできます.コードは以下の通りです.
    easyinstall requests
    

    しかし、端末は再び私に打撃を与えました.
    command not found
    

    またじっくり見て、WTF!命令が合っていないのはeasyだinstall、なるべくCVしないという信仰を持っている私たちとして、本当に何度も穴を落としましたね.やはり大法をコピーしたほうがいいです.では、正しい命令に変えてもう一度来ます.
    can't creat or remove files in install directory
    

    WTF? これは何ですか.またネットに戻ってみると、このコマンドにはroot権限が必要で、端末はrootユーザーに直接切り替えるコマンドがあるようですが、仕事で端末をあまり使わないので、しばらくsudoで解決しましょう.
    sudo easy_install requests
    

    今回の端末はやっと私が見たいものが現れました.
    Searching for requests
    Reading http://https://pypi.python.org/simple/requests/
    

    それから数秒も待っていないうちに、タイムアウトを直接提示して、このコマンドは私は貼らない(タイムアウトは壁のせいだと思いますが、stackoverflowは私が直面したすべての問題をほとんど解決できるので、私のパソコンはずっと壁をひっくり返していませんが、これは余談です).easy_Installというコマンドは、直接端末にそのモジュールをダウンロードするだけでなく、ローカルモジュールファイルをインストールすることもできます.http://https://pypi.python.org/simple/requests/開けて、中は2種類のフォーマットのファイルがあって、インターネットを利用して少し調べて、ダウンロードするべきです.tar.gz接尾辞の、ダウンロードしてから、easy_を試し続けますInstall、sudoを忘れないで、今度はeasy_installダウンロード後のモジュールファイルパス:
    sudo easy_install /Users/xinzhi/Desktop/requests-2.9.1.tar.gz
    

    今回はやっとインストールに成功しました!
    Installed /Library/Python/2.7/site-packages/requests-2.9.1-py2.7.egg
    Processing dependencies for request==2.9.1
    Finished processing dependencies for requests==2.9.1
    

    これで、欠けているモジュールは、やっとインストールに成功しました.pythonファイルを後で実行します.
    python autobuild.py -p Gomefxs.xcodeproj -s Gomefxs -t Gomefxs -o  ~/Desktop/Gomefxs.ipa
    

    このとき、端末はクレイジーなロゴ情報を開始し、ロゴ情報が終了すると、デスクトップ上の.ipaファイルも生成され、大成功しました.
    pythonコード
    次はpythonのコードで、中のCODEをSIGN_IDENTITYを自分の証明書に変えてPROVISIONING_PROFILEは自分の説明ファイルに変えて、USER_KEYとAPI_KEYはタンポポのもので、タンポポを使わないので、そのままこの情報を削除しました.直すべきところはこの4つだけです.
    from optparse import OptionParser
    import subprocess
    import requests
    
    #configuration for iOS build setting
    CODE_SIGN_IDENTITY = "iPhone Distribution: GOME Financial Holdings Investment CO., LTD"
    PROVISIONING_PROFILE = "4bbd193f-7a2a-414f-9c00-4310817c14af"
    CONFIGURATION = "Release"
    SDK = "iphoneos"
    
    
    # configuration for pgyer
    #pgyer setting
    PGYER_UPLOAD_URL    = "http://www.pgyer.com/apiv1/app/upload"
    DOWNLOAD_BASE_URL   = "http://www.pgyer.com"
    USER_KEY            = ""
    API_KEY             = ""
    
    
    def cleanBuildDir(buildDir):
        cleanCmd = "rm -r %s" %(buildDir)
        process = subprocess.Popen(cleanCmd, shell = True)
        process.wait()
        print "cleaned buildDir: %s" %(buildDir)
    
    
    def parserUploadResult(jsonResult):
        resultCode = jsonResult['code']
        if resultCode == 0:
            downUrl = DOWNLOAD_BASE_URL +"/"+jsonResult['data']['appShortcutUrl']
            print "Upload Success"
            print "DownUrl is:" + downUrl
        else:
            print "Upload Fail!"
            print "Reason:"+jsonResult['message']
    
    def uploadIpaToPgyer(ipaPath):
        print "ipaPath:"+ipaPath
        files = {'file': open(ipaPath, 'rb')}
        headers = {'enctype':'multipart/form-data'}
        payload = {'uKey':USER_KEY,'_api_key':API_KEY,'publishRange':'2','isPublishToPublic':'2', 'password':""}
        print "uploading...."
        r = requests.post(PGYER_UPLOAD_URL, data = payload ,files=files,headers=headers)
        if r.status_code == requests.codes.ok:
             result = r.json()
             parserUploadResult(result)
        else:
            print 'HTTPError,Code:'+r.status_code
    
    def buildProject(project, target, output):
        buildCmd = 'xcodebuild -project %s -target %s -sdk %s -configuration %s build CODE_SIGN_IDENTITY="%s" PROVISIONING_PROFILE="%s"' %(project, target, SDK, CONFIGURATION, CODE_SIGN_IDENTITY, PROVISIONING_PROFILE)
        process = subprocess.Popen(buildCmd, shell = True)
        process.wait()
    
        signApp = "./build/%s-iphoneos/%s.app" %(CONFIGURATION, target)
        signCmd = "xcrun -sdk %s -v PackageApplication %s -o %s" %(SDK, signApp, output)
        process = subprocess.Popen(signCmd, shell=True)
        (stdoutdata, stderrdata) = process.communicate()
    
        uploadIpaToPgyer(output)
        cleanBuildDir("./build")
    
    def buildWorkspace(workspace, scheme, output):
        process = subprocess.Popen("pwd", stdout=subprocess.PIPE)
        (stdoutdata, stderrdata) = process.communicate()
        buildDir = stdoutdata.strip() + '/build'
        print "buildDir: " + buildDir
        buildCmd = 'xcodebuild -workspace %s -scheme %s -sdk %s -configuration %s build CODE_SIGN_IDENTITY="%s" PROVISIONING_PROFILE="%s" SYMROOT=%s' %(workspace, scheme, SDK, CONFIGURATION, CODE_SIGN_IDENTITY, PROVISIONING_PROFILE, buildDir)
        process = subprocess.Popen(buildCmd, shell = True)
        process.wait()
    
        signApp = "./build/%s-iphoneos/%s.app" %(CONFIGURATION, scheme)
        signCmd = "xcrun -sdk %s -v PackageApplication %s -o %s" %(SDK, signApp, output)
        process = subprocess.Popen(signCmd, shell=True)
        (stdoutdata, stderrdata) = process.communicate()
    
        uploadIpaToPgyer(output)
        cleanBuildDir(buildDir)
    
    def xcbuild(options):
        project = options.project
        workspace = options.workspace
        target = options.target
        scheme = options.scheme
        output = options.output
    
        if project is None and workspace is None:
            pass
        elif project is not None:
            buildProject(project, target, output)
        elif workspace is not None:
            buildWorkspace(workspace, scheme, output)
    
    def main():
        
        parser = OptionParser()
        parser.add_option("-w", "--workspace", help="Build the workspace name.xcworkspace.", metavar="name.xcworkspace")
        parser.add_option("-p", "--project", help="Build the project name.xcodeproj.", metavar="name.xcodeproj")
        parser.add_option("-s", "--scheme", help="Build the scheme specified by schemename. Required if building a workspace.", metavar="schemename")
        parser.add_option("-t", "--target", help="Build the target specified by targetname. Required if building a project.", metavar="targetname")
        parser.add_option("-o", "--output", help="specify output filename", metavar="output_filename")
    
        (options, args) = parser.parse_args()
    
        print "options: %s, args: %s" % (options, args)
    
        xcbuild(options)
    
    if __name__ == '__main__':
        main()
    

    まとめ
    実はpythonファイルは他の人はすべてすでに書いたので、配置の過程の中で最も時間の長いのはpythonのrequestsモジュールをインストールすることです.このpythonの実現原理はネット上にたくさんあって、私は貼りません.