iOS

[Swift]Schemaを使用してURLの接続先を切り替える

投稿日:

はじめに

はじめまして、suzukiです。

本日はXcodeのSchemaを使用しURLの接続先を紹介したいと思います。

以前にURLの接続先の変更漏れがあったので、その時しておくべきだった事の備忘もかねて書かせていただきます。

まずSchemaを理解する前にBuildConfigurationについて説明させていただきます。

 

XCodeのBuildConfigurationとは

XCodeではBuildConfigurationという設定があります。

こちらは

  • 開発環境
  • 検証環境
  • 本番環境

等それぞれの環境に合わせて読み込むコードを変更したり、参照するファイルを異ならせたりすることが可能です。

たとえばですが

古いXCodeですとProvisioningProfileの設定で DebugとReleaseで異なるProvisioningProfileを設定おりました。

そちらもこのBuildConfigurationの設定を元に

アーカイブするときはデフォルトでReleaseの設定のためReleaseで設定したProvisioningProfile

RunするときはデフォルトでDebugの設定のためDebugで設定したProvisioningProfile

それぞれのファイルが読み込まれております。

スキーマとは

いよいよSchemaについてです。

Schemaとは前述のBuildConfigurationを元に

  • Build
  • Run
  • Test
  • Profile
  • Analyze
  • Archive

上記のコマンドごとにBuildConfigurationを選んで設定することができます。

開発環境のスキーマ 本番環境のスキーマを追加し設定してくことで、開発環境と本番環境の切り替えがとても簡単に行える様になります。

スキーマの追加方法

まずスキーマの追加方法ついて、上部のメニューバーから

Product > Schema > NewSchema と選択

新しくSchemaを追加するダイアログが表示されるのでの名前をつけてOKボタンを押しましょう。

新しく追加したスキーマはRunボタンの右側から変更できます。

 

スキーマの設定変更

スキーマの設定変更ついて

まず新しいSchemaを選択している状態にし

Product > Schema > Edit Schema と選択

Schemaの設定ダイアログが出てきます。

今回はRunの項目の変更を行います。

Runはシミュレータや実機で起動するときの設定です。

こちらのBuild Configurationの値をReleaseに変更しましょう。

これで今回確認を行いたい内容の動作確認が可能です。

開発と本番で異なる通信の接続先を設定する

それでは本題のコードです。

Schemaを使って自動化していきましょう。

まずは下記の様に定義をしておきましょう。他の箇所からも使いやすい様に共通のクラスなりを作ります。

続いて呼び出し箇所のコードですが下記の様に呼び出します。

実際に起動してみると

・最初からあるSchema

・新しく追加したSchema

それぞれ違うURLが作成される事が確認が取れます。

 

今回設定した内容は限定的な使い方です。

開発環境でビルドした時だけログ出力を行う等

開発と本番で異なる設定にしたい場合は是非とも検討してみてください。

さいごに

開発環境と本番用の環境を交互する際に設定まわりの変更を手動で行うことはめんどくさいです。

本番用のアプリの作成する時に万全の体調でも無いこともよくあります。

簡単で作業の少ない環境を整えることはミスをなくすため大事かと思います。

 

それでは、最後までありがとうございました。

blog-page_footer_336




blog-page_footer_336




-iOS
-

執筆者:


comment

メールアドレスが公開されることはありません。

CAPTCHA


関連記事

swift

【Swift】Xcode10.3でSwift5で書かれたプロジェクトでデリゲートが呼ばれない

1 はじめに2 起きた環境3 起きる条件3.1 コード上の条件3.2 ビルド時の条件4 再現4.1 テスト用コード5 対応策6 さいごに7 おすすめ書籍 はじめに こんにちはsuzukiです。Xcod ...

Swift Chartsライブラリでボリンジャーバンドを描画してみる。

1 はじめに2 ボリンジャーバンドとは2.1 ライブラリの導入2.2 描画の準備3 ボリンジャーバンドを描画する3.1 CombinedChartViewの設定3.2 CombinedChartVie ...

swift

Swiftでのパーミッション取得を簡単に

1 はじめに2 準備3 実装3.1 とりあえず表示3.2 カスタマイズ4 さいごに はじめに こんにちは、nukkyです。 今回は、アプリにはつきもののユーザへのパーミッションの確認を 簡単に行えるラ ...

CollectionViewのカスタムレイアウトを作ってみた

1 はじめに2 作成するレイアウト2.1 レイアウト2.2 手順3 prepare( )4 layoutAttributesForItem(at indexPath: IndexPath)5 layo ...

swift

月と日を選択するpickerを作る

1 はじめに1.1 前提条件2 サンプル2.1 ピッカーのイメージ2.2 ピッカーのxibファイル2.3 実装したカスタムクラス2.4 呼び出し元のコード3 簡単な解説3.1 MonthAndDayP ...

フォロー

follow us in feedly

blog-page_side_responsive

2018年7月
1234567
891011121314
15161718192021
22232425262728
293031 

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。