前言
在你的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
操作。
-
使用
Xcode9
打開你的工程
-
執行打包操作:Product -> Archive
打包完成後執行
export
操作(其中會需要你手動選擇你的相關provison profile
等信息),Xcode9
會自動生成exportOptionsPlist
文件,同時拷貝到你生成的ipa
包的同級目錄下。
- 直接使用
Xcode9
自動生成的exportOptionsPlist
文件來進行xcodebuild
的export
操作,或者拷貝文件內容到你原來的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><none></string>
</dict>
</plist>