<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>App ID on Liangweidong's blog</title><link>https://liangweidonggood.github.io/tags/app-id/</link><description>Recent content in App ID on Liangweidong's blog</description><generator>Hugo -- gohugo.io</generator><language>zh-cn</language><lastBuildDate>Tue, 15 Aug 2017 00:00:00 +0800</lastBuildDate><atom:link href="https://liangweidonggood.github.io/tags/app-id/index.xml" rel="self" type="application/rss+xml"/><item><title>iOS 应用开发与证书管理：开发者账号、Identifiers 与 Profiles</title><link>https://liangweidonggood.github.io/p/ios-zheng-shu-guan-li-2017/</link><pubDate>Tue, 15 Aug 2017 00:00:00 +0800</pubDate><guid>https://liangweidonggood.github.io/p/ios-zheng-shu-guan-li-2017/</guid><description>&lt;img src="https://liangweidonggood.github.io/p/ios-zheng-shu-guan-li-2017/image/cover.jpg" alt="Featured image of post iOS 应用开发与证书管理：开发者账号、Identifiers 与 Profiles" /&gt;&lt;h2 id="准备工作"&gt;准备工作
&lt;/h2&gt;&lt;p&gt;iOS 开发需要&lt;strong&gt;两样硬件&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;iPhone 手机&lt;/strong&gt;（调试设备，UDID 唯一）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Mac 电脑&lt;/strong&gt;（macOS 10.9+，钥匙串访问工具）&lt;/li&gt;
&lt;/ul&gt;

 &lt;blockquote&gt;
 &lt;p&gt;实际上没有 Mac 也可以用云 Mac（MacStadium、AWS EC2 Mac），但本地 Mac 是最舒服的方案。&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="一申请-apple-id"&gt;一、申请 Apple ID
&lt;/h2&gt;&lt;p&gt;如果已有 Apple ID 可跳过。访问 &lt;a class="link" href="https://appleid.apple.com" target="_blank" rel="noopener"
 &gt;https://appleid.apple.com&lt;/a&gt; 注册。建议用真实邮箱（后续找回密码用得到）。&lt;/p&gt;
&lt;h2 id="二申请开发者账号"&gt;二、申请开发者账号
&lt;/h2&gt;&lt;p&gt;访问 &lt;a class="link" href="https://developer.apple.com/account" target="_blank" rel="noopener"
 &gt;https://developer.apple.com/account&lt;/a&gt;&lt;/p&gt;
&lt;h3 id="账号类型"&gt;账号类型
&lt;/h3&gt;&lt;table&gt;
	&lt;thead&gt;
			&lt;tr&gt;
					&lt;th&gt;类型&lt;/th&gt;
					&lt;th&gt;费用&lt;/th&gt;
					&lt;th&gt;适用&lt;/th&gt;
			&lt;/tr&gt;
	&lt;/thead&gt;
	&lt;tbody&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;个人（Individual）&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;99 USD/年&lt;/td&gt;
					&lt;td&gt;独立开发者&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;组织（Organization）&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;99 USD/年&lt;/td&gt;
					&lt;td&gt;公司（需 D-U-N-S 编号）&lt;/td&gt;
			&lt;/tr&gt;
	&lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;注册流程：登录 → 选择类型 → 填写资料 → 付款 → 等待审核（1~3 天）。&lt;/p&gt;
&lt;h2 id="三申请-identifiersapp-id"&gt;三、申请 Identifiers（App ID）
&lt;/h2&gt;&lt;p&gt;App ID 是应用的唯一标识，对应一个 Bundle ID（如 &lt;code&gt;com.yourcompany.appname&lt;/code&gt;）。Bundle ID 不可重复，建议用反向域名：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;个人：&lt;code&gt;com.firstname.lastname.appname&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;公司：&lt;code&gt;com.companyname.appname&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id="创建步骤"&gt;创建步骤
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;登录后台 → Certificates, Identifiers &amp;amp; Profiles → Identifiers&lt;/li&gt;
&lt;li&gt;点击 &amp;ldquo;+&amp;rdquo; 添加&lt;/li&gt;
&lt;li&gt;选择 &lt;strong&gt;App IDs&lt;/strong&gt;，点击 Continue&lt;/li&gt;
&lt;li&gt;选择 &lt;strong&gt;App&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;填写 Description（如 &amp;ldquo;我的App&amp;rdquo;）和 Bundle ID（如 &lt;code&gt;com.example.app&lt;/code&gt;）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Capabilities&lt;/strong&gt;：勾选需要的能力（推送通知、Sign in with Apple、App Groups、HealthKit 等）&lt;/li&gt;
&lt;li&gt;点击 Continue → Register&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id="常用-capabilities"&gt;常用 Capabilities
&lt;/h3&gt;&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Push Notifications&lt;/strong&gt;：推送（必须生成 APNs 证书或 key）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Sign in with Apple&lt;/strong&gt;：Apple 登录&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;App Groups&lt;/strong&gt;：应用间共享数据&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Background Modes&lt;/strong&gt;：后台运行&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;HealthKit / HomeKit / Wallet&lt;/strong&gt;：健康/智能家居/钱包&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="四申请-certificates证书"&gt;四、申请 Certificates（证书）
&lt;/h2&gt;&lt;p&gt;iOS 证书分三类：&lt;/p&gt;
&lt;table&gt;
	&lt;thead&gt;
			&lt;tr&gt;
					&lt;th&gt;证书&lt;/th&gt;
					&lt;th&gt;用途&lt;/th&gt;
			&lt;/tr&gt;
	&lt;/thead&gt;
	&lt;tbody&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;Apple Development&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;开发期（真机调试）&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;Apple Distribution&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;发布期（App Store / Ad Hoc）&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;APNs SSL (Sandbox &amp;amp; Production)&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;推送通知（Sandbox 开发、Production 生产）&lt;/td&gt;
			&lt;/tr&gt;
	&lt;/tbody&gt;
&lt;/table&gt;
&lt;h3 id="申请步骤mac-钥匙串"&gt;申请步骤（Mac 钥匙串）
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;打开 Mac → 应用程序 → 实用工具 → &lt;strong&gt;钥匙串访问&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;菜单：钥匙串访问 → 证书助理 → &lt;strong&gt;从证书颁发机构请求证书&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;填写：
&lt;ul&gt;
&lt;li&gt;用户电子邮件：开发者邮箱&lt;/li&gt;
&lt;li&gt;常用名称：随便填&lt;/li&gt;
&lt;li&gt;CA 邮箱：留空&lt;/li&gt;
&lt;li&gt;请求是：选择&lt;strong&gt;存储到磁盘&lt;/strong&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;保存得到 &lt;code&gt;CertificateSigningRequest.certSigningRequest&lt;/code&gt; 文件&lt;/li&gt;
&lt;li&gt;回到 Apple Developer 后台 → Certificates → &amp;ldquo;+&amp;rdquo;&lt;/li&gt;
&lt;li&gt;选择证书类型（Apple Development / Apple Distribution）&lt;/li&gt;
&lt;li&gt;上传 .certSigningRequest 文件&lt;/li&gt;
&lt;li&gt;下载生成的 &lt;code&gt;.cer&lt;/code&gt; 证书&lt;/li&gt;
&lt;li&gt;双击 &lt;code&gt;.cer&lt;/code&gt; → 用钥匙串打开&lt;/li&gt;
&lt;li&gt;在钥匙串中找到该证书 → 右键 → 导出 → 保存为 &lt;code&gt;.p12&lt;/code&gt;（含私钥）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;strong&gt;p12 密码&lt;/strong&gt;：导出时设一个密码。&lt;strong&gt;别忘了这个密码&lt;/strong&gt;——CI/CD、Fastlane、跨电脑开发都要用。&lt;/p&gt;
&lt;h3 id="推送证书apns"&gt;推送证书（APNs）
&lt;/h3&gt;&lt;ul&gt;
&lt;li&gt;同上，但选 &lt;strong&gt;Apple Push Notification service SSL (Sandbox &amp;amp; Production)&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;同一个 App ID 可以同时有 Development 和 Production 推送证书&lt;/li&gt;
&lt;li&gt;iOS 13+ 起，&lt;strong&gt;也可以用 APNs Auth Key（.p8）&lt;/strong&gt; 替代 SSL 证书——一份 key 通用 Sandbox 和 Production&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="五添加调试设备"&gt;五、添加调试设备
&lt;/h2&gt;&lt;p&gt;调试设备必须先在 Apple Developer 后台注册 UDID。&lt;/p&gt;
&lt;h3 id="获取-udid"&gt;获取 UDID
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;iPhone 用数据线连接 Mac&lt;/li&gt;
&lt;li&gt;打开 iTunes（macOS Catalina 之前）/ Finder（Catalina 之后）&lt;/li&gt;
&lt;li&gt;点击 iPhone 图标&lt;/li&gt;
&lt;li&gt;在序列号区域&lt;strong&gt;点击&lt;/strong&gt;切换显示 UDID&lt;/li&gt;
&lt;li&gt;右键 → 复制&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id="添加到-apple-developer"&gt;添加到 Apple Developer
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;后台 → Devices → All → &amp;ldquo;+&amp;rdquo;&lt;/li&gt;
&lt;li&gt;填写：
&lt;ul&gt;
&lt;li&gt;Platform：iOS / tvOS / watchOS&lt;/li&gt;
&lt;li&gt;Device Name：随便（如 &amp;ldquo;iPhone 15 - Dev&amp;rdquo;）&lt;/li&gt;
&lt;li&gt;Device ID (UDID)：粘贴刚才复制的 UDID&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Register&lt;/li&gt;
&lt;/ol&gt;

 &lt;blockquote&gt;
 &lt;p&gt;个人开发者账号最多注册 &lt;strong&gt;100 台&lt;/strong&gt; 设备（每年重置一次）。&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="六申请-provisioning-profiles"&gt;六、申请 Provisioning Profiles
&lt;/h2&gt;&lt;p&gt;Profile 把 App ID + Certificates + Devices 串起来，是 Xcode 编译时真正要的&amp;quot;凭证包&amp;quot;。&lt;/p&gt;
&lt;h3 id="类型"&gt;类型
&lt;/h3&gt;&lt;table&gt;
	&lt;thead&gt;
			&lt;tr&gt;
					&lt;th&gt;Profile&lt;/th&gt;
					&lt;th&gt;用途&lt;/th&gt;
			&lt;/tr&gt;
	&lt;/thead&gt;
	&lt;tbody&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;iOS App Development&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;真机调试&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;Ad Hoc&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;内测（不上 App Store，最多 100 台设备）&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;&lt;strong&gt;App Store&lt;/strong&gt;&lt;/td&gt;
					&lt;td&gt;上架 App Store&lt;/td&gt;
			&lt;/tr&gt;
	&lt;/tbody&gt;
&lt;/table&gt;
&lt;h3 id="创建步骤-1"&gt;创建步骤
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;后台 → Profiles → All → &amp;ldquo;+&amp;rdquo;&lt;/li&gt;
&lt;li&gt;选择类型 → Continue&lt;/li&gt;
&lt;li&gt;选择 App ID → Continue&lt;/li&gt;
&lt;li&gt;选择证书（Apple Development / Apple Distribution）→ Continue&lt;/li&gt;
&lt;li&gt;选择调试设备（仅 iOS App Development / Ad Hoc）→ Continue&lt;/li&gt;
&lt;li&gt;命名 Profile（如 &amp;ldquo;MyApp Dev&amp;rdquo;）→ Generate&lt;/li&gt;
&lt;li&gt;下载 &lt;code&gt;.mobileprovision&lt;/code&gt; 文件&lt;/li&gt;
&lt;li&gt;双击安装到 Xcode&lt;/li&gt;
&lt;/ol&gt;

 &lt;blockquote&gt;
 &lt;p&gt;添加新设备后必须&lt;strong&gt;重新生成 Profile&lt;/strong&gt;——老的 Profile 不会自动包含新设备。&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="七xcode-中配置"&gt;七、Xcode 中配置
&lt;/h2&gt;&lt;ol&gt;
&lt;li&gt;打开 Xcode → 项目 → Signing &amp;amp; Capabilities&lt;/li&gt;
&lt;li&gt;勾选 &lt;strong&gt;Automatically manage signing&lt;/strong&gt;（Xcode 自动管理）&lt;/li&gt;
&lt;li&gt;Team 选择你的 Apple Developer Team&lt;/li&gt;
&lt;li&gt;Bundle Identifier 填刚才创建的 App ID&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;或者手动管理：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;取消勾选 Automatically manage signing&lt;/li&gt;
&lt;li&gt;Provisioning Profile 选择刚才下载的&lt;/li&gt;
&lt;li&gt;Signing Certificate 选择对应的证书&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id="八构建并跑真机"&gt;八、构建并跑真机
&lt;/h2&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# Xcode 选中真机（不是模拟器）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# Product -&amp;gt; Run (Cmd + R)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;首次运行会弹窗要求信任证书：设置 → 通用 → VPN 与设备管理 → 信任开发者。&lt;/p&gt;
&lt;h2 id="常见问题"&gt;常见问题
&lt;/h2&gt;&lt;h3 id="no-code-signing-identities-found"&gt;&amp;ldquo;No code signing identities found&amp;rdquo;
&lt;/h3&gt;&lt;p&gt;证书没装到钥匙串。重新双击 &lt;code&gt;.cer&lt;/code&gt; 文件。&lt;/p&gt;
&lt;h3 id="failed-to-create-provisioning-profile"&gt;&amp;ldquo;Failed to create provisioning profile&amp;rdquo;
&lt;/h3&gt;&lt;p&gt;Profile 中没有包含当前设备。重新生成 Profile（包含新设备 UDID）。&lt;/p&gt;
&lt;h3 id="bundle-identifier-conflict"&gt;&amp;ldquo;Bundle Identifier conflict&amp;rdquo;
&lt;/h3&gt;&lt;p&gt;Bundle ID 全局唯一，换一个。&lt;/p&gt;
&lt;h3 id="推送收不到"&gt;推送收不到
&lt;/h3&gt;&lt;ul&gt;
&lt;li&gt;检查 Capabilities 是否勾选 Push Notifications&lt;/li&gt;
&lt;li&gt;检查 APNs 证书是否过期（开发证书 1 年，生产证书 1 年）&lt;/li&gt;
&lt;li&gt;改用 &lt;strong&gt;APNs Auth Key (.p8)&lt;/strong&gt; 不会过期&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="2024-视角自动签名app-store-connect-apitestflight"&gt;2024+ 视角：自动签名、App Store Connect API、TestFlight
&lt;/h2&gt;&lt;p&gt;本文 2017 年写时，Xcode 的&amp;quot;自动签名&amp;quot;还是&lt;strong&gt;可选功能&lt;/strong&gt;（Xcode 8 引入但很多团队不敢用）。7 年后（2024），自动签名已经是&lt;strong&gt;事实标准&lt;/strong&gt;——配合 App Store Connect API + TestFlight + Fastlane，整套流程可以做到&lt;strong&gt;零人工、零 .p12 邮件&lt;/strong&gt;。下面是当前的最佳实践。&lt;/p&gt;
&lt;h3 id="1-自动签名automatic-signing-现在不用会累死"&gt;1. 自动签名（Automatic Signing）—— 现在不用会累死
&lt;/h3&gt;&lt;p&gt;&lt;strong&gt;Xcode 14+（2022-09）&lt;/strong&gt;：自动签名能力再次大幅增强。&lt;/p&gt;
&lt;h4 id="11-项目配置"&gt;1.1 项目配置
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-text" data-lang="text"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;# Xcode → Project → Target → Signing &amp;amp; Capabilities
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;☑ Automatically manage signing
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; Team: &amp;lt;Your Team ID&amp;gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; Bundle Identifier: com.example.app
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;之后&lt;/strong&gt;——Xcode 会自动：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;创建/更新 App ID&lt;/li&gt;
&lt;li&gt;创建/更新 Provisioning Profile（Development / Ad Hoc / Distribution）&lt;/li&gt;
&lt;li&gt;关联证书&lt;/li&gt;
&lt;li&gt;写入 &lt;code&gt;*.xcodeproj/project.pbxproj&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;好处&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;新员工入职 → &lt;strong&gt;登录 Apple ID 即可&lt;/strong&gt;（不用再走&amp;quot;申请证书 → 申请 Profile → 导出 p12&amp;quot;流程）&lt;/li&gt;
&lt;li&gt;Bundle ID 改名 → Xcode 自动重建&lt;/li&gt;
&lt;li&gt;新增设备 UDID → Xcode 自动重生成 Dev Profile&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;没有 p12 邮件&lt;/strong&gt;——告别 &lt;code&gt;.p12&lt;/code&gt; + 密码在企业微信群里传来传去&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id="12-仍然需要手动的场景"&gt;1.2 仍然需要手动的场景
&lt;/h4&gt;&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;企业内部分发&lt;/strong&gt;（In-House / Enterprise）——仍需手动建 Enterprise Profile&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;跨电脑同步证书&lt;/strong&gt;——见下节&amp;quot;钥匙串共享&amp;quot;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;多 Target / 多 Bundle ID&lt;/strong&gt;——Target 数量多时仍需手动管理&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id="2-app-store-connect-api替代手工点网页"&gt;2. App Store Connect API（替代手工点网页）
&lt;/h3&gt;&lt;p&gt;&lt;strong&gt;2018 年 Apple 推出 App Store Connect API&lt;/strong&gt;，到 2024 年已经覆盖&lt;strong&gt;几乎所有&lt;/strong&gt;手动操作（上传构建、创建版本、提交审核、管理 TestFlight、管理用户等）。&lt;/p&gt;
&lt;h4 id="21-创建-api-key"&gt;2.1 创建 API Key
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-fallback" data-lang="fallback"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;App Store Connect → Users and Access → Keys → App Store Connect API → Generate
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;得到 3 项：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Issuer ID&lt;/strong&gt;（团队级，UUID）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Key ID&lt;/strong&gt;（单 key 唯一）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;.p8 文件&lt;/strong&gt;（私钥，&lt;strong&gt;只能下载一次&lt;/strong&gt;）&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id="22-用-api-key-上传构建不再用-transporter-gui"&gt;2.2 用 API Key 上传构建（不再用 Transporter GUI）
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 安装 xcrun（Xcode 自带）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;xcrun altool --upload-app &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --type ios &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --file MyApp.ipa &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --apiKey ABC123XYZ &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --apiIssuer 12345678-90ab-cdef-1234-567890abcdef
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;vs 旧版 Transporter&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;✅ 可脚本化（CI/CD 友好）&lt;/li&gt;
&lt;li&gt;✅ 不需要交互登录&lt;/li&gt;
&lt;li&gt;✅ 不需要 2FA 验证码&lt;/li&gt;
&lt;li&gt;✅ 一台机器一个 .p8，不受 Mac 换机影响&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id="23-用-api-key-自动创建版本--提交审核"&gt;2.3 用 API Key 自动创建版本 / 提交审核
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt; 1
&lt;/span&gt;&lt;span class="lnt"&gt; 2
&lt;/span&gt;&lt;span class="lnt"&gt; 3
&lt;/span&gt;&lt;span class="lnt"&gt; 4
&lt;/span&gt;&lt;span class="lnt"&gt; 5
&lt;/span&gt;&lt;span class="lnt"&gt; 6
&lt;/span&gt;&lt;span class="lnt"&gt; 7
&lt;/span&gt;&lt;span class="lnt"&gt; 8
&lt;/span&gt;&lt;span class="lnt"&gt; 9
&lt;/span&gt;&lt;span class="lnt"&gt;10
&lt;/span&gt;&lt;span class="lnt"&gt;11
&lt;/span&gt;&lt;span class="lnt"&gt;12
&lt;/span&gt;&lt;span class="lnt"&gt;13
&lt;/span&gt;&lt;span class="lnt"&gt;14
&lt;/span&gt;&lt;span class="lnt"&gt;15
&lt;/span&gt;&lt;span class="lnt"&gt;16
&lt;/span&gt;&lt;span class="lnt"&gt;17
&lt;/span&gt;&lt;span class="lnt"&gt;18
&lt;/span&gt;&lt;span class="lnt"&gt;19
&lt;/span&gt;&lt;span class="lnt"&gt;20
&lt;/span&gt;&lt;span class="lnt"&gt;21
&lt;/span&gt;&lt;span class="lnt"&gt;22
&lt;/span&gt;&lt;span class="lnt"&gt;23
&lt;/span&gt;&lt;span class="lnt"&gt;24
&lt;/span&gt;&lt;span class="lnt"&gt;25
&lt;/span&gt;&lt;span class="lnt"&gt;26
&lt;/span&gt;&lt;span class="lnt"&gt;27
&lt;/span&gt;&lt;span class="lnt"&gt;28
&lt;/span&gt;&lt;span class="lnt"&gt;29
&lt;/span&gt;&lt;span class="lnt"&gt;30
&lt;/span&gt;&lt;span class="lnt"&gt;31
&lt;/span&gt;&lt;span class="lnt"&gt;32
&lt;/span&gt;&lt;span class="lnt"&gt;33
&lt;/span&gt;&lt;span class="lnt"&gt;34
&lt;/span&gt;&lt;span class="lnt"&gt;35
&lt;/span&gt;&lt;span class="lnt"&gt;36
&lt;/span&gt;&lt;span class="lnt"&gt;37
&lt;/span&gt;&lt;span class="lnt"&gt;38
&lt;/span&gt;&lt;span class="lnt"&gt;39
&lt;/span&gt;&lt;span class="lnt"&gt;40
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-python" data-lang="python"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 用 PyJWT 签 JWT，调用 App Store Connect REST API&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="nn"&gt;jwt&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="nn"&gt;time&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="nn"&gt;requests&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;KEY_ID&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;ABC123XYZ&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;ISSUER_ID&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;12345678-90ab-cdef-1234-567890abcdef&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;PRIVATE_KEY&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nb"&gt;open&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;AuthKey_ABC123XYZ.p8&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;read&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 1. 签 JWT&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;token&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;jwt&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;encode&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;iss&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;ISSUER_ID&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;iat&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;time&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;time&lt;/span&gt;&lt;span class="p"&gt;()),&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;exp&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;time&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;time&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1200&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;aud&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;appstoreconnect-v1&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;PRIVATE_KEY&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;algorithm&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;ES256&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;headers&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;kid&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;KEY_ID&lt;/span&gt;&lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 2. 创建新版本&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;r&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;requests&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;post&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;https://api.appstoreconnect.apple.com/v1/appStoreVersions&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;headers&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;Authorization&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="sa"&gt;f&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;Bearer &lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="n"&gt;token&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;json&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;data&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;type&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;appStoreVersions&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;attributes&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;versionString&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;1.2.0&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;platform&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;IOS&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;relationships&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;app&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;data&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;type&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;apps&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;id&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;1234567&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;}}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;},&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="nb"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;r&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;json&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;h3 id="3-testflight-2024-现状"&gt;3. TestFlight 2024 现状
&lt;/h3&gt;&lt;p&gt;&lt;strong&gt;Xcode 14+ 起 TestFlight 体验大幅提升&lt;/strong&gt;：&lt;/p&gt;
&lt;table&gt;
	&lt;thead&gt;
			&lt;tr&gt;
					&lt;th&gt;特性&lt;/th&gt;
					&lt;th&gt;2017 状态&lt;/th&gt;
					&lt;th&gt;2024 状态&lt;/th&gt;
			&lt;/tr&gt;
	&lt;/thead&gt;
	&lt;tbody&gt;
			&lt;tr&gt;
					&lt;td&gt;内测名额&lt;/td&gt;
					&lt;td&gt;25 个内部 + 1000 外部&lt;/td&gt;
					&lt;td&gt;100 个内部 + 10000 外部&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;外部测试&lt;/td&gt;
					&lt;td&gt;需 Apple 审核&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;不再需要&lt;/strong&gt;（自动通过）&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;构建有效期&lt;/td&gt;
					&lt;td&gt;60 天&lt;/td&gt;
					&lt;td&gt;90 天&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;群组管理&lt;/td&gt;
					&lt;td&gt;后台手动&lt;/td&gt;
					&lt;td&gt;API 自动化&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;安装方式&lt;/td&gt;
					&lt;td&gt;邮件 / 链接&lt;/td&gt;
					&lt;td&gt;TestFlight App / 公开链接 / QR Code&lt;/td&gt;
			&lt;/tr&gt;
	&lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;TestFlight 公开链接&lt;/strong&gt;（2020 推出）：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-fallback" data-lang="fallback"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;https://testflight.apple.com/join/XXXXXXXX
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;任何人点链接&lt;/strong&gt; → 安装 TestFlight App → 收到邀请 → 安装内测版。&lt;strong&gt;适合 50 人以内的小范围灰度&lt;/strong&gt;。&lt;/p&gt;
&lt;h3 id="4-fastlane-match--证书管理的正确姿势"&gt;4. Fastlane match —— 证书管理的&amp;quot;正确姿势&amp;quot;
&lt;/h3&gt;&lt;p&gt;本文 2017 时 Fastlane 还很新，2024 已经成熟到&amp;quot;不用不专业&amp;quot;。&lt;/p&gt;
&lt;h4 id="41-match-是什么"&gt;4.1 match 是什么
&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;把证书和 Profile 集中存到一个 Git 仓库&lt;/strong&gt;（可以是私有 GitLab/Gitee），全团队共享。&lt;strong&gt;新员工入职 = 拉一次 git 仓库 = 拿到所有证书&lt;/strong&gt;。&lt;/p&gt;
&lt;h4 id="42-初始化"&gt;4.2 初始化
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;span class="lnt"&gt;7
&lt;/span&gt;&lt;span class="lnt"&gt;8
&lt;/span&gt;&lt;span class="lnt"&gt;9
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 1. 装 fastlane&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;sudo gem install fastlane
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 2. 在项目根目录初始化&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;fastlane match init
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 3. 创建证书 + Profile（一次性）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;fastlane match appstore &lt;span class="c1"&gt;# App Store 分发&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;fastlane match development &lt;span class="c1"&gt;# 真机调试&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;h4 id="43-在-cicd-里用"&gt;4.3 在 CI/CD 里用
&lt;/h4&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;span class="lnt"&gt;7
&lt;/span&gt;&lt;span class="lnt"&gt;8
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# CI 拉证书&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;fastlane match appstore --readonly &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --git_url git@gitlab.example.com:mobile/ios-certificates.git &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --git_branch main &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; --app_identifier com.example.app
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 接着打包&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;fastlane build_release
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;好处&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;不再用邮件发 p12&lt;/strong&gt;——告别&amp;quot;证书密码忘了&amp;quot;、&amp;ldquo;p12 过期&amp;rdquo;、&amp;ldquo;新员工入职没人理&amp;rdquo;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;CI 机器无障碍&lt;/strong&gt;——GitHub Actions / GitLab CI 直接拉&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;审计友好&lt;/strong&gt;——所有证书变更都有 git 提交记录&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id="5-钥匙串共享跨-mac-同步"&gt;5. 钥匙串共享（跨 Mac 同步）
&lt;/h3&gt;&lt;p&gt;如果仍然用手动签名 + 跨 Mac 开发，&lt;strong&gt;用 iCloud 钥匙串&lt;/strong&gt;：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-fallback" data-lang="fallback"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;系统设置 → 通用 → Apple ID → iCloud → 钥匙串 ☐→☑
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;之后&lt;/strong&gt;——所有登录 Apple ID 的 Mac 自动共享证书 / 私钥。&lt;strong&gt;新 Mac 登录 = 5 分钟拿到所有签名材料&lt;/strong&gt;。&lt;/p&gt;
&lt;h3 id="6-2024-ios-证书管理完整流程推荐"&gt;6. 2024 iOS 证书管理完整流程（推荐）
&lt;/h3&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt; 1
&lt;/span&gt;&lt;span class="lnt"&gt; 2
&lt;/span&gt;&lt;span class="lnt"&gt; 3
&lt;/span&gt;&lt;span class="lnt"&gt; 4
&lt;/span&gt;&lt;span class="lnt"&gt; 5
&lt;/span&gt;&lt;span class="lnt"&gt; 6
&lt;/span&gt;&lt;span class="lnt"&gt; 7
&lt;/span&gt;&lt;span class="lnt"&gt; 8
&lt;/span&gt;&lt;span class="lnt"&gt; 9
&lt;/span&gt;&lt;span class="lnt"&gt;10
&lt;/span&gt;&lt;span class="lnt"&gt;11
&lt;/span&gt;&lt;span class="lnt"&gt;12
&lt;/span&gt;&lt;span class="lnt"&gt;13
&lt;/span&gt;&lt;span class="lnt"&gt;14
&lt;/span&gt;&lt;span class="lnt"&gt;15
&lt;/span&gt;&lt;span class="lnt"&gt;16
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-gdscript3" data-lang="gdscript3"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;首次（一次性）：&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;1.&lt;/span&gt; &lt;span class="err"&gt;团队&lt;/span&gt; &lt;span class="n"&gt;Leader&lt;/span&gt; &lt;span class="err"&gt;跑&lt;/span&gt; &lt;span class="n"&gt;fastlane&lt;/span&gt; &lt;span class="n"&gt;match&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="err"&gt;→&lt;/span&gt; &lt;span class="err"&gt;创建&lt;/span&gt; &lt;span class="n"&gt;App&lt;/span&gt; &lt;span class="n"&gt;ID&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="n"&gt;Cert&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="n"&gt;Profile&lt;/span&gt; &lt;span class="err"&gt;→&lt;/span&gt; &lt;span class="err"&gt;推到&lt;/span&gt; &lt;span class="n"&gt;Git&lt;/span&gt; &lt;span class="err"&gt;仓库&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;日常开发：&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;2.&lt;/span&gt; &lt;span class="err"&gt;新员工&lt;/span&gt; &lt;span class="n"&gt;git&lt;/span&gt; &lt;span class="n"&gt;pull&lt;/span&gt; &lt;span class="err"&gt;证书仓库&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;3.&lt;/span&gt; &lt;span class="n"&gt;fastlane&lt;/span&gt; &lt;span class="n"&gt;match&lt;/span&gt; &lt;span class="n"&gt;development&lt;/span&gt; &lt;span class="o"&gt;--&lt;/span&gt;&lt;span class="n"&gt;readonly&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;4.&lt;/span&gt; &lt;span class="n"&gt;Xcode&lt;/span&gt; &lt;span class="err"&gt;打开&lt;/span&gt; &lt;span class="err"&gt;→&lt;/span&gt; &lt;span class="err"&gt;自动签名（团队&lt;/span&gt; &lt;span class="n"&gt;ID&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="n"&gt;Bundle&lt;/span&gt; &lt;span class="n"&gt;ID&lt;/span&gt; &lt;span class="err"&gt;一致就行）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;CI&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt;&lt;span class="n"&gt;CD&lt;/span&gt;&lt;span class="err"&gt;：&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;5.&lt;/span&gt; &lt;span class="n"&gt;GitLab&lt;/span&gt; &lt;span class="n"&gt;CI&lt;/span&gt; &lt;span class="err"&gt;跑&lt;/span&gt; &lt;span class="n"&gt;fastlane&lt;/span&gt; &lt;span class="n"&gt;match&lt;/span&gt; &lt;span class="n"&gt;appstore&lt;/span&gt; &lt;span class="o"&gt;--&lt;/span&gt;&lt;span class="n"&gt;readonly&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;6.&lt;/span&gt; &lt;span class="n"&gt;fastlane&lt;/span&gt; &lt;span class="n"&gt;build&lt;/span&gt; &lt;span class="err"&gt;→&lt;/span&gt; &lt;span class="n"&gt;altool&lt;/span&gt; &lt;span class="err"&gt;上传到&lt;/span&gt; &lt;span class="n"&gt;App&lt;/span&gt; &lt;span class="n"&gt;Store&lt;/span&gt; &lt;span class="n"&gt;Connect&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;上架：&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;7.&lt;/span&gt; &lt;span class="n"&gt;App&lt;/span&gt; &lt;span class="n"&gt;Store&lt;/span&gt; &lt;span class="n"&gt;Connect&lt;/span&gt; &lt;span class="n"&gt;API&lt;/span&gt;&lt;span class="err"&gt;（&lt;/span&gt;&lt;span class="n"&gt;JWT&lt;/span&gt;&lt;span class="err"&gt;）创建版本、提交审核&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mf"&gt;8.&lt;/span&gt; &lt;span class="err"&gt;用&lt;/span&gt; &lt;span class="n"&gt;TestFlight&lt;/span&gt; &lt;span class="err"&gt;公开链接做灰度&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;对比 2017&lt;/strong&gt;：从&amp;quot;邮件发 p12、群里问密码、找运维加 UDID&amp;quot; → &amp;ldquo;git pull + fastlane 一条命令&amp;rdquo;。&lt;strong&gt;工程师精力从 1 天降到 5 分钟&lt;/strong&gt;。&lt;/p&gt;
&lt;h3 id="7-2024-关键工具版本"&gt;7. 2024+ 关键工具版本
&lt;/h3&gt;&lt;table&gt;
	&lt;thead&gt;
			&lt;tr&gt;
					&lt;th&gt;工具&lt;/th&gt;
					&lt;th&gt;2017 主流&lt;/th&gt;
					&lt;th&gt;2024 主流&lt;/th&gt;
			&lt;/tr&gt;
	&lt;/thead&gt;
	&lt;tbody&gt;
			&lt;tr&gt;
					&lt;td&gt;Xcode&lt;/td&gt;
					&lt;td&gt;8.x&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;15.x / 16 beta&lt;/strong&gt;（2024）&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;iOS SDK&lt;/td&gt;
					&lt;td&gt;iOS 10/11&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;iOS 17 / 18 beta&lt;/strong&gt;&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;Swift&lt;/td&gt;
					&lt;td&gt;3.x&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;5.9 / 5.10&lt;/strong&gt;&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;TestFlight&lt;/td&gt;
					&lt;td&gt;内测 25 人&lt;/td&gt;
					&lt;td&gt;100 + 10000 + 公开链接&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;证书管理&lt;/td&gt;
					&lt;td&gt;手动 / 邮件 p12&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;fastlane match&lt;/strong&gt; + 自动签名&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;上传工具&lt;/td&gt;
					&lt;td&gt;Transporter GUI&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;xcrun altool&lt;/strong&gt; + App Store Connect API&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;签名方式&lt;/td&gt;
					&lt;td&gt;手动&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;Xcode 自动签名&lt;/strong&gt;&lt;/td&gt;
			&lt;/tr&gt;
			&lt;tr&gt;
					&lt;td&gt;Provisioning Profile&lt;/td&gt;
					&lt;td&gt;手动生成&lt;/td&gt;
					&lt;td&gt;&lt;strong&gt;自动生成&lt;/strong&gt;（Xcode 14+）&lt;/td&gt;
			&lt;/tr&gt;
	&lt;/tbody&gt;
&lt;/table&gt;
&lt;h3 id="8-一句话总结"&gt;8. 一句话总结
&lt;/h3&gt;
 &lt;blockquote&gt;
 &lt;p&gt;2017 年的 iOS 签名是&amp;quot;&lt;strong&gt;每个工程师都要会手动申请证书&lt;/strong&gt;&amp;ldquo;的工程师成年礼；
2024 年是&amp;rdquo;&lt;strong&gt;自动签名 + fastlane match + App Store Connect API + TestFlight 公开链接&lt;/strong&gt;&amp;ldquo;的&amp;quot;零证书知识&amp;quot;时代。&lt;/p&gt;
&lt;p&gt;新人&lt;strong&gt;不要再学手动签名&lt;/strong&gt;——直接 fastlane match 拉仓库、Xcode 自动签名，几分钟搞定。&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;hr&gt;
&lt;h2 id="下一步"&gt;下一步
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;想把 IPA 上架 App Store，看 2019-11-15《iOS App Store 上架》&lt;/li&gt;
&lt;li&gt;想用 Fastlane 自动化证书 + 打包，看 &lt;a class="link" href="https://docs.fastlane.tools/actions/match/" target="_blank" rel="noopener"
 &gt;fastlane match 官方文档&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;想接 App Store Connect API，看 &lt;a class="link" href="https://developer.apple.com/documentation/appstoreconnectapi" target="_blank" rel="noopener"
 &gt;Apple 官方文档&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="参考资料"&gt;参考资料
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;Apple Developer：https://developer.apple.com/account&lt;/li&gt;
&lt;li&gt;证书管理：https://developer.apple.com/help/account&lt;/li&gt;
&lt;li&gt;Bundle ID 命名规范：https://developer.apple.com/documentation/bundleresources&lt;/li&gt;
&lt;li&gt;APNs 文档：https://developer.apple.com/documentation/usernotifications&lt;/li&gt;
&lt;li&gt;App Store Connect API：https://developer.apple.com/documentation/appstoreconnectapi&lt;/li&gt;
&lt;li&gt;fastlane match：https://docs.fastlane.tools/actions/match/&lt;/li&gt;
&lt;li&gt;Xcode 自动签名：https://developer.apple.com/documentation/xcode/automatic-signing&lt;/li&gt;
&lt;/ul&gt;</description></item></channel></rss>