Edited at

iPhone/iPadにDelphi/C++Builder開発アプリを配置する手順(実機への配置)

More than 1 year has passed since last update.


iPhone/iPadにアプリを配置する手順

この記事は 別記事「[Hello World] iOS アプリをDelphiで作ってみよう」の続きです。そして、当記事は 「【超入門】iOSアプリ開発をDelphi/C++Builderで始めるためのファーストステップ」としてまとめられている記事の一部でもあります。

が、iOSアプリを作る前段階としてのXcode8におけるプロビジョニング設定手順の参考としてもご覧いただけます。

さて、前記事にて、シミュレーターでの動作ができたら、次は、実際にiPhone/iPadデバイスにアプリを配置して動作させましょう。アプリを「配置」する観点で、iOSアプリを大きく3つの種類に分けてみました。異論は認める。

アプリの種類
主な用途

開発
開発用で、特定のデバイスにアプリを配置してテストなど行うための形態

アドホック
ストア通さず配布し、テスト用に特定のデバイス配布したり、実稼働用に配布して使用。企業内でのみ使用する業務アプリなどで使用される種類

アプリケーションストア
App Store に登録して広く配布し、AppStoreからダウンロードして使用する種類。広く誰にでも使ってもらう方法

これら、アプリの用途(種類)ごとに「プロビジョニング」、というものを設定しなければなりません。この記事では、まず、「開発」用のプロビジョニングを設定して、iOSのアプリの開発、テストが行えるようにします。


使用環境

ここで手順ご紹介に使用しているOS,ソフトウエアなどのバージョンなどを記載します。

環境
バージョン

Windows
10 バージョン 1607 ビルド 14393.969

RAD Studio / Delphi / C++Builder
10.2 Tokyo

macOS
Sierra バージョン 10.12.4

iOS
10.3.1

Parallels 11 for Mac
11.2.2

Xcode
8.3.1 *注1

*1 : 2017年4月現在、Xcodeは8.2の使用を推奨(8.3はRAD Studioとの相性問題あり)


アプリケーションのプロビジョニング

開発しているアプリを実際にiPhone/iPadデバイスへテスト用に配置(デプロイ、と言います)して実行したり、アプリをアドホック(ストアを経由しないで配布インストールして使う方法)としてiOSデバイスにインストールしたり、Appleストアへ申請したりするには、アプリが「署名」されていなければなりません。そして、「署名」されているには、「デベロッパー証明書」というものを取得していなければなりません。そして「デベロッパー証明書」を取得するには、Apple Developer Programに参加しなければなりません。

そうやって手続きを終えたのちに、アプリのID、APP IDを取得し、デバイス情報、証明書と合わせて「プロビジョニング」します。順に見ていきましょう。


Apple Developer Program(アップルデベロッパープログラム)への参加



  1. AppleIDをもっていなければ取得しておきます。AppleIDとはなんぞや?という方はこちらのアップルサポートの記事をどうぞ


  2. Apple デベロッパー プログラム加入登録します。年会費が必要です。この記事を書いている2017年4月現在では、個人向け年間 11,800円、法人向け年間 37,800円です。(Appleの購入とアクティベーションサポート情報)

説明があっさりしていますが、こんなものです。Appleのデベロッパ申し込みWebの手順を記載しても、時折手順が変わることもあるとのことなので、ここにはAppleのWebサイト内での詳細手順は転記せず進めておきます。AppleのWebに従って進めてください(丸投げ)

ここからはプロビジョニングの作成まで、実際の詳細な手順を見てみましょう。ちなみに「端折った手順」もあります。楽な方法を選びたい方は「端折った手順」をご参照ください。端折ったオートマチックなやり方では、本質はつかめない!細かいこと通してやることで本質を覚えるんだ!って方はこのまま読み進んでください。(端折ったほうが「開発」アプリを作るうえでは簡単でオススメです)


証明書の取得

前述のとおり、アプリに署名するには「デベロッパ証明書」を取得しなければなりません。これはAppleに要求して取得します。要求と言っても手作業で申請とかするわけではなく、macOS上のXcodeでポチッとやるだけです。

Apple公式の手順はこちらに記載されています。

証明書は、用途ごとに用意する必要があります。その用途別はiOS向けには2種類あります。

証明書の種類
説明

iOSアプリ開発用 (iOS Development)
開発中にiOSデバイスでアプリを実行するため

iOS配布用 (iOS Distribution)
指定したデバイスにテスト用、Ad Hocとして配布、またはストア登録するため

などなど。他にもmacOSアプリ開発用や、macOSアプリのストア登録用や、macOSアプリでストアには登録時内で配布する物用、などいくつかあります。 くわしくはAppleサポートのドキュメントをご参照ください。 それでは手順にはいります。


  1. macOS上でXcodeを起動します。

  2. [Xcode]-[Preferences]を選択して環境設定を開きます。

  3. [Accounts] をクリックします。

  4. 初めての開発アプリ作成なら、ここのAccountsにはアカウントが表示されていません。左下の[+]ボタンをクリックして[Add Apple ID...] を選択します。



  5. 表示されるダイアログ「Sign in to Xcode with Your Apple ID」に「Apple デベロッパー プログラム」登録したApple IDとパスワードを入力し、[Sign In]をクリックします。


  6. Apple IDがアカウントとして表示されます。今度は右下の「Manage Certificate...]ボタンをクリックします。「Signing certificates for (Apple ID)」ダイアログが現れ、取得済の署名証明書が表示されます。取得歴がなければ、表示されません。


  7. 「Signing certificates for (Apple ID)」ダイアログの左下の[+]ボタンをクリックして表示される [iOS Development]をクリックします。



  8. 「Signing certificates for (Apple ID)」ダイアログに「iOS Development Certificate」が追加されます。


  9. [Done]をクリックしてダイアログを閉じます。


これで証明書は取得できました。この方法を使うと、取得した証明書はmacOSのキーチェーンにも自動的に登録されます。


実機の登録

今度は動作させるデバイスを登録します。「プロビジョニング」には動作させるデバイス情報も必要なんです。


  1. 開発用アプリを送り込みたいiPhone/iPadをMacに接続します。(USB+Lightning)ケーブルで物理的に接続してください。

  2. iPhone/iPadに接続したデバイスを信頼するかどうかの問い合わせが出てるかと思いますので、「信頼する」をタップします。

  3. macOSの上部ツールバーのXcodeのメニュー内、[Window] - [Devises]を選択します。

  4. 接続している(アプリを開発するアプリを配置したい)iOSデバイスが左側に表示されているので、それをクリックします。

  5. デバイス情報が表示されます。このデバイス情報の「identifier」をコピーしておいてください。


  6. Appleデベロッパーアカウント Web ページにいき、ログインします。

  7. Web ページの「Certificates, Identifiers & Profiles」をクリックします



  8. 左下の「Devices]の「All」をクリックします。


  9. All Devecisesが表示されるので、右上の「+」ボタンをクリックします。


  10. デバイス登録ページが表示されるので、デバイスの名前(好きなデバイス名でOK)と、先ほどコピーした「identifier」をUDIDに入力します。



  11. 一番下に表示されている[Continue]をクリックします。


  12. 画面が切り替わったら、情報が正しいかか確認の上、一番下に表示されている[Register]をクリックします。


  13. [Done]をクリックすると「All Deceives」のページに戻ります。


これで実機登録完了です。


APP IDの取得

今度は配置するアプリのIDを作成します。「プロビジョニング」にはアプリのIDも必要なんです。

が、開発向けのプロビジョニングでは、最初から登録されている ワイルドカードAPP IDが使えるので、ここでは新規追加せずに、APP IDの在りかのご紹介まで。



  1. Appleデベロッパーアカウント Web ページにいき、ログインします。

  2. Web ページの「Certificates, Identifiers & Profiles」をクリックします

  3. 左の「Identifiers]の[App IDs]をクリックします。デフォルトで存在している Xcode iOS Wildcard App ID などが表示されているはずです。


「Xcode iOS Wildcard AppID」 といったワイルドカードのAppIDがデフォルトで存在しているのを確認いただけるかと思います。存在しない場合には、下記の手順でワールドカードAPP IDを作っておきましょう。すでにワイルドカードがあるときには作らなくてOKです。


  1. 右上の[+]ボタンをクリックし、

  2. App ID Descriptionに[my Wildcard]名称をセット(名称は好きな名前でOK)

  3. App ID Suffixに「Wildcard AppID], Bundle IDに[*]をセット

  4. その後[Continue] - [Register]ボタンをクリック

  5. [Done]ボタンをクリック


App IDは以上。


プロビジョニングプロファイルの作成

いよいよプロビジョニングまで到達しました。では、作りましょう、プロビジョニングプロファイル。



  1. Appleデベロッパーアカウント Web ページにいき、ログインします。

  2. Web ページの「Certificates, Identifiers & Profiles」をクリックします

  3. 左下の下の「Provisioning Profile」の[All]をクリックします。



  4. 右上に表示されている「+」をクリックします。


  5. どんなタイプのプロビジョニングを必要としているか問い合わせされるので、[Development] - [iOS App Development] を選択し、下部に表示されている[Continue]をクリックします。


  6. App IDを選択するように言われるので[Xcode iOS Wildcard App ID]、もしくは先のApp IDのセクションで作ったワイルドカードApp IDを選択して、下部に表示されている[Continue]をクリックします。開発向けであれば、とりあえず、このApp IDでOK。App perchesなどの機能が使えないので、本格稼働のときには、個別のApp IDを別途作ってあげればいいです。


  7. Certificates(証明書)を選ぶように言われるので、 「証明書の取得」のセクションで作っておいたiOS Development の証明書を選択して[Continue]をクリックします。


  8. デバイスを選ぶようにいわれるので、「実機の登録」のセクションで登録した、アプリを配置したいデバイスを選択して[Continue]をクリックします。


  9. プロファイル名を決めてプロビジョニングを生成するように言われるので、プロファイルネームをお好きに設定して[Continue]をクリックします。


  10. 「Your provisioning profile is ready」(プロビジョニングプロファイルの準備ができました)たと表示され、「Download]ボタンが表示されますので、これをクリック。ダウンロードが開始され、ダウンロードフォルダに保存されます。


  11. Doneをクリックします。



これで、プロビジョニングファイルが作成され、プロビジョニングも有効(アクティブ)な状態になりました!次の手順では、このプロビジョンングプロファイルを、開発アプリを動作させる実機にインストールします。


動作実機へプロビジョニングプロファイルをインストール

さて、開発アプリをiOSデバイス上で動作させるためには、動作させる実機上に対応するプロビジョニングプロファイルがインストールされていなければなりません。下記手順にて先ほど作ったプロビジョニングプロファイルを実機にインストールしていきます。


  1. 開発用アプリを送り込みたいiPhone/iPadをMacに接続します。(USB+Lightning)ケーブルで物理的に接続してください。

  2. Xcodeを起動します。

  3. macOSの上部ツールバーのXcodeのメニュー内、[Window] - [Devises]を選択します。

  4. 接続している(アプリを開発するアプリを配置したい)iOSデバイスが左側に表示されているので、それをクリックします。

  5. 先ほど、ダウンロードしたプロビジョニングプロファイルのファイル(デフォルトで「Downloads」」フォルダにダウンロードされている)をダブルクリックします。これでプロビジョニングファイルが、実機にインストールされました。

  6. 次に、実機に、プロファイルが正しくインストールされたか、確認してみます。デバイス情報が表示されているダイアログの、左側に表示されているiOSデバイス(アイコン)を二本指タップしてコンテキストメニューを表示し、[Show Provisioning Profiles]を選択します。
    2.「Provisioning profiles installed on xx(デバイス名)」のダイアログが表示されます。

    インストールします。
    ここに先ほどのプロビジョニングプロファイル名が表示されていれば、実機にプロファイルがインストールできています。

もし、表示されていなければ、


  1. 左下の「+」をクリックします。

  2. 「Select a provisioning profile to install on the device] (デバイスにインストールするプロビジョンングファイルを選択)ダイアログが表示されるので、「プロビジョニングファイルの作成」手順で作成して、ダウンロードしているプロビジョニングファイル(デフォルトで「Downloads」」フォルダにダウンロードされている)を選択して[Install]をクリックします。

  3. [Done]ボタンをクリックします。

これで、プロビジョニングファイルがiOSデバイス実機にインストールされました。

次の手順では、開発環境から、開発アプリを実機に配置(デプロイ)してみましょう。


iPhone / iPad アプリを実機に配置

開発アプリをDelphi/ C++Builder / RAD Studio で ビルドして 実機へと配置します。

事前準備として macOS側で PA Serverを起動しておいてください。 もし、PA Serverが前述のプロビジョニングプロファイル作成前から起動しっぱなしだった場合には、一度終了させて、再起動させておいてください。

PA Server、なんのことだかわからんよ?という方は 別記事XcodeのインストールとPAServerのインストール をご参照ください。

では手順の説明に入ります。


  1. RAD Studioを起動します。

  2. [ツール] - [オプション] を選択し、オプションウインドウを開きます。

  3. 左側のオプションリストから「プロビジョニング」をクリックします。

  4. プロビジョニングの「ビルドの種類(B)」に[iOS デバイス - 64bit 開発」を選択します。

  5. 自動的に先ほどの手順で作成したプロビジョニングプロファイルが選択され「選択したエンティティ」に情報が表示されます。確認し[OK]をクリックします。先ほど作成したアドホック用のプロビジョニングファイルではない場合(※要注意)、「プロビジョンプロファイル」のドロップダウンから、正しいプロファイルを選択して、[OK]をクリックしてください。


  6. なにかアプリを作ります。前の記事で作ったHello world アプリでもよいでしょう。作り終わったら次の手順へ。

  7. プロジェクトマネージャのターゲットプラットフォームにて[iOSデバイス - 64bit - ...]を選択します。

  8. ターゲットプラットフォームにて[iOSデバイス - 64bit - ...]の下位レベルにある「ターゲット」フォルダを開くと、macOS側に接続されている、実機iOS機が表示されているはずです。表示されていなければ、右クリックで表示される「更新」を選択してください。

  9. 表示されている実機iOS機の名称をダブルクリックすると、太字で強調表示され、ターゲットとしてセットされます。

  10. 同列に表示されている[構成]フォルダを開き、[開発]をダブルクリックすると、太字で強調表示され、ターゲットとしてセットされます。



  11. それではビルド(実行)してみましょう。[Shift+Ctrl+F9]キーを押す、もしくはツールバー上の緑三角の[デバッガを使わずに実行]ボタンをクリックします。この時、心の中で"デプロイ!"と叫びます。決して声に出してはいけません。


  12. macOS側で「Codesignはキーチェーンに含まれるキー"xxxx"へアクセスしようとしています」とダイアログが出ますので、「常に許可」もしくは「許可」をクリックします。


  13. そのまましばらく待つと、iOSデバイス側で、アプリが起動してきます。



以上で「開発」目的のアプリの配置は完了となります。 うまくいかない、というかたは、下記の「端折った方法」も試してみてください。


最後に端折った方法をご紹介します。

Xcode8では、上記で記載している、証明書、App ID, device ID からプロファイルの作成まで自動で行い、「開発」目的のアプリをiOSデバイスにまで送り込んでくれるオプションがあります。

つまり、上述の、面倒な開発用プロビジョンプロファイルの作成を自動でやってくれるんです!

これを使ってサクッとプロビジョニング作成をおこなってしまおう、というのが、この「端折った手順」の趣旨です。

※Adhocやストア登録向けのプロビジョニングプロファイルを作成したい場合には、上述の面倒な丁寧な手順にて設定を行うことが必要なようです。

子の端折った方法を使って設定を行っている方法についてビデオを公開しています。

こちらもご参考にどうぞ: https://youtu.be/r9vgMLSzloU

では、手順、参りましょう。


  1. Xcodeを起動します。

  2. XcodeのWelcomeページから [Create a new Xcode Project]を選びます。

  3. Choose a template for your new project では「Single View Application」を選択して、[Next]をクリック



  4. 作成するアプリの基本情報登録ダイアログに切り替わるので、Project Nameに任意の名前を入れます。ここでは [Test]と入力しました。Team欄や Organization Name欄にはご自分のApple ID登録名を入力しておけばよいかと。Team欄に過去、自分のApple IDを入力したことがない場合には、Apple IDの入力とパスワードを求められますので、それを入力してから、Team名にご自分のApple IDを選択しなおしてださい。


  5. [Next]ボタンをクリックします。


  6. おもむろに保存場所選択と思われるダイアログが開くので、「Create]をクリック

    デバッグのアクセス許可を求められるので、お使いのmacOSのアカウントパスワードを入力して続行。


  7. これで真っ白な画面を表示するだけの基本APPが作られたことになります。


  8. 次に、iOSデバイスを接続します。開発用アプリを送り込みたいiPhone/iPadをMacに接続します。(USB+Lightning)ケーブルで物理的に接続してください。

    iPhone/iPadに接続したデバイスを信頼するかどうかの問い合わせが出てるかと思いますので、「信頼する」をタップします。


  9. 接続がうまくいって、少々待つと左上のプロジェクト名で対象のiOSデバイスが選択できるようになりますので、これを指定しておきます。


  10. 中央あたりの「Signing」で[Automatically manage Signing] のチェックボックスをONにします。


  11. 同様にTeam欄は、先ほどと同じく自分のApple IDの登録名をいれておきます。


  12. ここまできたら、Xcode左上の右向き三角マークをクリックします。



  13. これで、ビルドが開始され、真っ白な画面のみが表示されるアプリが実機に送り込まれます。


※実機を繋いですぐビルドすると、「iphone busy processing symbol filesエラー 」というダイアログが出ることがあります。このとき、Xcode中央上のステータス表示を見ると「Processing Symbol Files」と表示されプログレスバーがゆっくり動いているかとおもいます。このプログレスが終わってから、再度ビルドにチャレンジしてください。

さて、ここまで成功すると、内部的には、プロビジョニングファイルが作られ、iOS機にもプロビジョニングファイルがインストールされた状態になります。

つまり、前述のセクションの「証明書作成」~「プロビジョニング作成」まで自動でやってくれるのです!

あとは「iPhone / iPad アプリを実機に配置」のセクションに記述していることを実施するのみです。

それではiOSアプリの開発をお楽しみください。


"デプロイ!" できない!

上記手順をなぞってやってみても、デプロイしたときにエラーが出てiOS実機に配置できない、ということが時々あります。そんなことになっていた時期が私にもありました。

これを回避するためにいくつかやったことを、参考として載せておきます。


  • 基本として、エラーの時にRAD Studioに表示されるダイアログにいくつか解決のためのヒントがのっているので、まずはそれを参照してみる。

  • Xcode上で同名の証明書を複数取得していないか確認。もし複数あったらリボークして1つにしてみる。

  • キーチェーンに同名の証明書がのこっていないか? [Launchpad] - [その他] - [キーチェーンアクセス] で表示されるキーや証明書でリボークされたものが残っていないか?複数同名キーが登録されていないか?を確認。もしあったら削除しておく。

  • 上記に関連するプロファイル情報がのこっていないか?無効な証明書、過去に作ったプロファイルはmacOSの /Users/[ユーザー名]/Library/MobileDevice/Provisioning Profiles/の中に残っている場合があるので、これを削除。

証明書、プロファイル関連の重複や、古いものをクリーンアップしてあげると解決することがあるということですね。