Xcode9 xcodebuild export plist 配置 前言 一、現象 二、原因 三、解決步驟 參考

前言

在你的iOS團隊中,如果在使用持續集成來完成自動化打包分發的工作,你可能會了解如何使用一些命令行工具來構建ipa文件,其中一款使用較爲廣泛的是xcodebuild

在我們的團隊中有部分打包工作就是使用的xcodebuild,腳本代碼大概如下:

ipaName = "${scheme}${buildConfiguration}"
// archive
xcodebuild -workspace ProjectName.xcworkspace -scheme ${scheme} -configuration ${buildConfiguration} clean archive -archivePath ./${ipaName}.xcarchive
// export
xcodebuild -exportArchive -archivePath ${ipaName}.xcarchive -exportOptionsPlist exportOptions_dev.plist -exportPath ./

exportOptions_dev文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>method</key>
    <string>development</string>
    <key>teamID</key>
    <string>yourTeamID</string>
</dict>
</plist>

以上配置在Xcode8及以下版本都可以正常運行的,在升級Xcode9以後上面的腳本會在export階段出錯。

一、現象

  • xcodebuild + Xcode9
    使用xcodebuild做打包構建時,執行exportArchive命令出錯,錯誤信息:
error: exportArchive: "AppName.app" requires a provisioning profile with the Push Notifications and App Groups features.
Error Domain=IDEProvisioningErrorDomain Code=9
"AppName.app" requires a provisioning profile with the Push Notifications and App Groups features." UserInfo={NSLocalizedDescription="AppName.app" requires a provisioning profile with the Push Notifications and App Groups features., NSLocalizedRecoverySuggestion=Add a profile to the "provisioningProfiles" dictionary in your Export Options property list.}
// 或
"Error Domain=IDEProvisioningErrorDomain Code=9 \"\"ios-simple-objc.app\" requires a provisioning profile.\"
UserInfo={NSLocalizedDescription=\"ios-simple-objc.app\" requires a provisioning profile., NSLocalizedRecoverySuggestion=Add a profile to the \"provisioningProfiles\" dictionary in your Export Options property list.}"

二、原因

Xcode9 的打包需要指定以下信息,才能完成export操作:

  • provisioningProfiles
  • compileBitcode
  • method
  • signingCertificate
  • signingStyle
  • stripSwiftSymbols
  • teamID
  • thinning

三、解決步驟

你需要使用Xcode9先手動構建一次,使用構建生成的plist配置就可以完成export操作。

  1. 使用Xcode9打開你的工程

  2. 執行打包操作:Product -> Archive


  3. 打包完成後執行export操作(其中會需要你手動選擇你的相關provison profile等信息),Xcode9會自動生成exportOptionsPlist文件,同時拷貝到你生成的ipa包的同級目錄下。

  1. 直接使用Xcode9自動生成的exportOptionsPlist文件來進行xcodebuildexport操作,或者拷貝文件內容到你原來的exportOptionsPlist文件。
// Xcode9 export 生成的文件
DistributionSummary.plist
ExportOptions.plist
AppName.ipa
Packaging.log

四、示例

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>compileBitcode</key>
    <true/>
    <key>method</key>
    <string>development</string>
    <key>provisioningProfiles</key>
    <dict>
        <key>com.xingshulin.abc</key>
        <string>abc_dev</string>
        <key>com.xingshulin.abc.NotificationServiceExtension</key>
        <string>abc-Notification-dev</string>
    </dict>
    <key>signingCertificate</key>
    <string>iPhone Developer</string>
    <key>signingStyle</key>
    <string>manual</string>
    <key>stripSwiftSymbols</key>
    <true/>
    <key>teamID</key>
    <string>yourTeamID</string>
    <key>thinning</key>
    <string>&lt;none&gt;</string>
</dict>
</plist>

參考

New export options Plist in Xcode 9

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章