環(huán)境變量xcconfig的使用

一、配置的初衷:每次app在Release和Debug模式下都要來回改正式與測試的 BaseUrl以及其他的url或者常量,有可能忘記改,我們就上線,結(jié)果就可想而知,于是為了避免手動(dòng)更改的麻煩和犯錯(cuò)誤,我們才去配置環(huán)境

二、通過Debug和Release代碼的判斷來配置,如下

#ifdef DEBUG
#define BaseURL @"[https://test.app/api/](https://test.app/api/)"
#else
#define BaseURL @"[https://app/api/](https://app/api/)"
#endif

建議:把上述代碼放在一個(gè)單獨(dú)的.h文件里面,在需要使用的時(shí)候?qū)腩^文件即可,這樣會(huì)更加簡潔,職能更加專一,更好維護(hù),但是這不是最好的方式,最好的方式通過Xcode中的Configurations Setting Fil(.xcconfig)來解決,這應(yīng)該是最優(yōu)的實(shí)現(xiàn)方式,從而根據(jù)Debug和Release來選擇相應(yīng)的環(huán)境,看下面 三 的配置

三、Configurations Setting Fil(.xcconfig)的配置步驟

3.1、創(chuàng)建三個(gè) Configuration Settings File 文件,該文件的后綴為.xcconfig, 三個(gè)文件的命名分別命名為Common.xcconfig, Debug.xcconfig, Release.xcconfig, 其中 Debug.xcconfig和Release.xcconfig 可以使用#include來包含Common.xcconfig配置文件, 注意在創(chuàng)建.xcconfig的時(shí)候Xcode默認(rèn)是不會(huì)選中Targets的,注意要選中!
提示:Common.xcconfig, Debug.xcconfig, Release.xcconfig三個(gè)文件的名字自己可以隨便起,不想改就以這三個(gè)名字就好,下面我就把這三個(gè)名字前都加上 JK,如:JKCommon.xcconfig,JKDebug.xcconfig,JKRelease.xcconfig

3.2、下面以 JKCommon.xcconfig 為例創(chuàng)建,JKDebug.xcconfig和JKRelease.xcconfig一樣

image.png

JKCommon.xcconfig 為例創(chuàng)建

image.png

JKCommon.xcconfig 為例創(chuàng)建

image.png

配置后的圖

  • 3.3、Debug 和 Release 模式下對上面 文件的的配置

JKDebug.xcconfig 配置

include "JKCommon.xcconfig"
// 測試下基礎(chǔ)的URL
JKURL = @"https:/$()/test.com/api/api/"
// 是測試的環(huán)境
JK_IS_PRODUCATION = NO

JKRelease.xcconfig 配置

include "JKCommon.xcconfig"
// 正式下基礎(chǔ)的URL
JKURL = @"https:/()/app.com/api/api/" // 是正式的環(huán)境 JK_IS_PRODUCATION = YES 提示:在 //之間使用()來轉(zhuǎn)義,如:JKURL = @"https:/$()/app.com/api/api/"

3.5、在 JKCommon.xcconfig中配置相應(yīng)的 JKURL 與 JK_IS_PRODUCATION,如下

GCC_PREPROCESSOR_DEFINITIONS = (inherited) JKURL='(JKURL)' JK_IS_PRODUCATION='$(JK_IS_PRODUCATION)'

image.png

JKCommon.xcconfig中配置相應(yīng)的 JKURLJK_IS_PRODUCATION

提示:

  • Common.xconfig中第一個(gè)鍵的配置必須有 :GCC_PREPROCESSOR_DEFINITIONS = $(inherited),沒有Xcode會(huì)報(bào)錯(cuò)
  • 自定義鍵時(shí)的語法:宏名='(key)', 在代碼或其他地方使用宏名來引用,'(key)':通過key來指定每個(gè)模式下的對應(yīng)的自定義鍵的名字,通常將宏的名字和key的名字保持一致,注意 等號前后一定不能有空格
  • 特別注意:``Common.xconfig中第一個(gè)key是GCC_PREPROCESSOR_DEFINITIONS = $(inherited) 后面跟自定義的key,注意在第一個(gè)key后面跟上自己定義的key的時(shí)候一定不要回車換行,敲一個(gè)空格,然后在同一行后面追加就行了,換行會(huì)編譯錯(cuò)誤,切記!
  • 3.6、在 TARGETS —> Build Settings —> Preprocessor Macros 下查看自己的配置,入下
image.png

TARGETS —> Build Settings —> Preprocessor Macros 下查看自己的配置

四、上面配置完,我們來測試一下是否好使

4.1、在 Debug 模式下測試

NSLog(@"JKURL=%@",JKURL);

打印結(jié)果如下

JKURL=https://test.com/api/api/

image.png

Debug 模式下測試

  • 4.2、在 Release 模式下測試

NSLog(@``"JKURL=%@"``,JKURL);

打印結(jié)果如下

JKURL=https:``//app.com/api/api/

image.png

在 ** Release** 下測試

  • 4.3、上面測試的 demo
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容