2022-10-12 15:21:04 +08:00
+++
author = "FlintyLemming"
title = "Xcode 里 App 的多环境管理"
slug = "3f3589d42a244fad8bb293185db8514f"
date = "2022-10-12"
description = ""
categories = ["Coding", "Apple"]
tags = ["Xcode"]
2025-01-23 16:43:06 +08:00
image = "https://image.mitsea.com/blog/posts/2022/10/Xcode%20%E9%87%8C%20App%20%E7%9A%84%E5%A4%9A%E7%8E%AF%E5%A2%83%E7%AE%A1%E7%90%86/title.avif"
2022-10-12 15:21:04 +08:00
+++
软件开发中一般需要对应不同的环境发布不同的成品,比如 Dev、Prod 等。通过使用 Xcode 的 scheme 可以管理多个环境,并在不同的环境下执行不同的行为。
首先需要明白两个概念, Scheme 和 Configuration。上面这个叫 Schema, 下面的是 Configuration。
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/35ad2/35ad25d60adcb1b87e62fea03d53736b710ff1e5" alt=""
2022-10-12 15:21:04 +08:00
你可以简单理解为包含关系,每个 Schema 里的 Debug、Build 等行为配置是参考 Configuration 里的项目。
## 创建 Configurations
1. 点击项目 Info 里 Configurations 下面的加号,可以以默认的 Debug 和 Release 为模板,创建多个 Configurations
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/2e5f2/2e5f2509c0997f3fe34c3a5f54af9f3d462c5d1f" alt=""
2022-10-12 15:21:04 +08:00
2. 每个环境里的 Debug 和 Release 还是要区分开的,所以这边创建出了如下的 Configurations。默认的那一组 Debug 和 Release 就当内部本地用,但是考虑到 Xcode 的草台性,不建议改它名字。
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/f4241/f4241c525374eb3cfe2da3182bb90342e8ff6c59" alt=""
2022-10-12 15:21:04 +08:00
3. 为了在代码里能够让代码根据不同的环境执行不同的行为,我们还需要给刚才创建的 Configurations 设置 Flag。在 Build Settings 里找到 Swift Compiler - Custom Flags 里的 Active Compilation Conditions。
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/ee05c/ee05c3ef5554fd3fd2230b11c85780de23c546c1" alt=""
2022-10-12 15:21:04 +08:00
4. 最后就是这样
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/b5b31/b5b3132a2f752d1a5d866f985496860f796c95d5" alt=""
2022-10-12 15:21:04 +08:00
## 创建 Scheme
创建完 Configurations 还不够,因为我们还不能很方便的去控制当前我们编译 App 的时候到底用哪套 Configuration, 这个时候就需要创建多个 Scheme
1. 点击这里的 Manage Schemes
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/01f5d/01f5d99747573d1fea3c1b6008f429d921cfaca4" alt=""
2022-10-12 15:21:04 +08:00
2. 创建多个 Scheme, 可以把默认的改成 Local
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/93450/93450f58dec6d700732d653365a2133c80184d85" alt=""
2022-10-12 15:21:04 +08:00
3. 双击编辑,比如双击这里的 MyApp-Dev。Run 里的这个 Build Configuration 就要改成刚才创建的 Debug Dev
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/7a21c/7a21c23e0e59ac559c5c84682b4c62440b092e3a" alt=""
2022-10-12 15:21:04 +08:00
4. 这五个行为里面的都要改,比如 Release 要改成刚才创建的 Release Dev
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/8aa1a/8aa1a5c24ade41cb9c6f469e4a1c7dc3bf13e071" alt=""
2022-10-12 15:21:04 +08:00
5. 同理,另一个 MyApp-Prod 的 scheme 里也要都改掉,这样当我们点击这里切换的时候,就会使用不同的 Configuration
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/e613d/e613d81aa37d5a28ef43789fdb8249948411c548" alt=""
2022-10-12 15:21:04 +08:00
## 编辑不同环境下的行为
### 代码逻辑
可以使用下面的这种语法为不同环境编写不同的逻辑代码
```swift
#if LOCAL
demoText.text = "Now is Local Environment"
#elseif DEV
demoText.text = "Now is Dev Environment"
#elseif PROD
demoText.text = "Now is Prod Environment"
#endif
```
看下效果
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/36899/36899ff2496051e32deaf69d9f6e349a311d38b1" alt=""
2022-10-12 15:21:04 +08:00
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/c5720/c57206de92c63de56e3353aa00c930e4afc4eb52" alt=""
2022-10-12 15:21:04 +08:00
### 包名
不同环境包名可能都是不一样的。在 Siging & Capabilities 里,可以看到这里已经有刚才创建的选项了,只需要点击对应的选项,修改里面的 Bundle Identifier 即可。
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/7da70/7da700567d696cb3e2903ae57b66eed3764f05e9" alt=""
2022-10-12 15:21:04 +08:00
### 显示名称
不同环境的显示名称也可能不一样,在 General 里修改
2025-01-23 16:43:06 +08:00
data:image/s3,"s3://crabby-images/d938b/d938bec21cbbb5a702e999089d5a7ec2ee3f0f0f" alt=""
2022-10-12 15:21:04 +08:00
此外还有很多可以区分环境设置, 包括代码中引用的变量、App Icon 等等……
> Photo by [Skylar McKissack](https://unsplash.com/@skymckissack?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText) on [Unsplash](https://unsplash.com/?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText)