コンテンツにスキップ
アカウントを作成
または
サインイン
Stripe ドキュメントのロゴ
/
AI に質問する
アカウントを作成
サインイン
始める
支払い
売上
プラットフォームおよびマーケットプレイス
資金管理
Developer resources
概要
Stripe Payments について
構築済みのシステムをアップグレード
支払いの分析
オンライン決済
概要ユースケースを見つけるManaged Payments
Payment Links を使用する
決済ページを構築
高度なシステムを構築
アプリ内実装を構築
    概要
    Payment Sheet
    Embedded Payment Element
    アプリ内購入のリンク
      構築済みの決済ページを使用する
      Payment Links を使用する (ローコード)
      カスタムフローを構築する
    住所を収集
    アメリカとカナダのカード
決済手段
決済手段を追加
決済手段を管理
Link による購入の迅速化
支払いインターフェイス
Payment Links
Checkout
Web Elements
アプリ内 Elements
決済シナリオ
複数の通貨を扱う
カスタムの決済フロー
柔軟なアクワイアリング
オーケストレーション
店頭支払い
端末
Beyond payments
Incorporate your company
仮想通貨
Financial Connections
Climate
ホーム支払いBuild an in-app integrationLink out for in-app purchases

Payment Links を使用して iOS でデジタル商品の支払いを受け付ける

アプリから Stripe 上のオンライン決済ページにリンクして、デジタル商品やサブスクリプションを販売します。

一部の国では、外部のウェブサイトをリンクして、iOS で支払いを受け付けられます。このガイドでは、Stripe ダッシュボードでローコードの決済用リンクを作成し、そのリンクを使用してアプリから Stripe 上のオンライン決済ページに顧客をリダイレクトする方法をご紹介します。URL パラメーターを使用してリンクを動的に更新し、顧客のメールアドレスを事前入力したり、client_reference_id を使用してユーザーのアプリ ID または一意の識別子を渡したりできます。

Payment Links は、サーバーを立ち上げる必要がないため、商品と価格が限られている場合に最適なオプションです。より動的なカートを提供したり、顧客をセッションに関連付けたりする場合は、代わりに Stripe Checkout を使用することをお勧めします。

注

このガイドでは、アプリ内のデジタル商品を販売するプロセスのみについて説明します。以下のいずれかを販売している場合は、代わりにネイティブ iOS の支払いガイドを使用してください。

  • 物理的品目
  • アプリ外での使用を目的とする商品やサービス
  • 2 人の個人間の、対人リアルタイムサービス

作成する内容

このガイドでは以下の方法を説明します。

  • 商品 と 価格を使用して、デジタル商品またはサブスクリプションをモデル化します。
  • ダッシュボードから決済用リンクを作成します。
  • ユニバーサルリンクを使用して 決済用リンクからアプリへと直接リダイレクトします。
  • Webhook を監視して顧客のアプリ内サブスクリプションを更新します。

対象範囲外の内容

このガイドでは、既存のアプリ内購入システムと並行して決済用リンクを追加する方法を説明します。以下は対象範囲に含まれません。

  • ユーザー認証。既存の認証プロバイダーがない場合には、Sign in with Apple (Apple でサインイン) や Firebase Authentication などのサードパーティプロバイダーを使用できます。
  • ネイティブのアプリ内購入。StoreKit を使用してアプリ内購入を実装するには、Apple のアプリ内課金 ガイドをご覧ください。

ユニバーサルリンクを設定する
クライアント側
サーバー側

ユニバーサルリンクを使用すると、決済成功後に、決済用リンクをお使いのアプリにディープリンクできます。ユニバーサルリンクを設定するには、次の手順を行います。

  1. ドメインに apple-app-site-association ファイルを追加します。
  2. アプリに Associated Domains エンタイトルメントを追加します。
  3. Checkout リダイレクト URL のフォールバックページを追加します。

関連ドメインを定義する

.well-known/apple-app-site-association でドメインにファイルを追加し、アプリで処理する URL を定義します。アプリ ID の前にチーム ID を付加します。チーム IDは、Apple Developer Portal のメンバーシップページにあります。

.well-known/apple-app-site-association
{ "applinks": { "apps": [], "details": [ { "appIDs": [ "A28BC3DEF9.com.example.MyApp1", "A28BC3DEF9.com.example.MyApp1-Debug" ], "components": [ { "/": "/checkout_redirect*", "comment": "Matches any URL whose path starts with /checkout_redirect" } ] } ] } }

警告

このファイルは、MIME タイプ application/json で提供する必要があります。curl -I を使用してコンテンツタイプを確認します。

Command Line
curl -I https://example.com/.well-known/apple-app-site-association

詳細については、関連ドメインのサポートに関する Apple のページを参照してください。

アプリに Associated Domains エンタイトルメントを追加する

  1. アプリのターゲットの、Signing & Capabilities (署名とケイパビリティ) ウィンドウを開きます。
  2. + ケイパビリティ をクリックし、関連ドメイン を選択します。
  3. applinks:example.com のエントリーを Associated Domains リストに追加します。

ユニバーサルリンクの詳細については、Apple のユニバーサルリンクのドキュメントを参照してください。

iOS は、apple-app-site-association ファイルで定義された URL へのリンクをインターセプトしますが、リダイレクトでアプリを開くことができないケースが発生することがあります。

商品またはサブスクリプションの決済用リンクを作成する

  1. ダッシュボードで Payment Links ページを開き、+新規をクリックします (または、プラス記号 (+) をクリックして決済用リンクを選択します)。
  2. 任意: 顧客が支払い金額を選択する を選択して、顧客が希望する金額を支払えるようにすることもできます (たとえば、購入するクレジットの数を決定するなど)。
  3. 既存の商品を選択するか、+新しい商品を追加 をクリックします。
  4. 新しく商品を追加する場合は、商品詳細を入力して 商品を追加 をクリックします。
  5. 支払い後 に移動し、確認ページを表示しない を選択します。
  6. 成功 URL としてユニバーサルリンクを設定し、支払い完了後に顧客をあなたのアプリに誘導します。
  7. リンクを作成 をクリックします

Payment Links は、カード支払いと Apple Pay にデフォルトで対応しています。ダッシュボードから追加の支払い方法を有効にできます。

URL パラメーターを使用して関連情報を添付する

URL パラメーターを使用すると、決済ページにその他の詳細情報を追加して、決済を効率化できます。URL パラメーターを使用して、決済ページの言語を変えたり、メールアドレスやプロモーションコードを事前入力したり、関連付けられたメタデータを添付して照合しやすくしたりできます。

prefilled_email と client_reference_id の使用をお勧めします。決済が効率化され、照合が容易になります。

パラメータ説明構文

prefilled_email

prefilled_email を使用して、決済ページにメールアドレスを自動的に入力します。顧客は引き続きこのフィールドを編集できるため、決済フローに渡すメールアドレスが、支払いを完了するために使用されるメールアドレスとは異なる場合があります。

prefilled_email は有効なメールアドレスにする必要があります。無効な値は通知なく破棄されますが、決済ページは引き続き正常に機能します。

URL パラメーターとして付与するメールアドレスは、決済ページに渡されないリスクを下げるために、エンコーディングすることをお勧めします。

client_reference_idclient_reference_id を使用して、Checkout セッションに選択した一意の文字列を関連付けます。アプリ ID やカート ID (または同様のもの) を指定でき、内部システムでセッションを照合するために使用できます。この値は決済時に顧客には表示されませんが、支払いの完了後に checkout.session.completed Webhook で送信されます。client_reference_id は、英数字、ダッシュ、アンダースコアで構成され、最大 200 文字の任意の値を指定できます。無効な値は通知なしに削除されますが、決済ページは引き続き正常に機能します。

以下は、prefilled_email と client_reference_id が指定されたリンクの例です。

https://buy.stripe.com/test_eVa3do41l4Ye6KkcMN?prefilled_email=jenny%40example.com&client_reference_id=id_123

アプリにリンクを追加する

アプリに決済ボタンを追加します。このボタンは以下を行います。

  • 決済用リンクに prefilled_email と client_reference_id を事前入力します。
  • Stripe 上のオンライン決済ページを Safari で開きます。

注文のフルフィルメントを処理する
サーバー側

購入が成功すると、Stripe は checkout.session.completed Webhook を送信します。Webhook イベントのペイロードでは、checkout.session object に client_reference_id があり、これをビジネスロジックに使用できます。たとえば、支払いをシステム内の特定の注文や顧客に関連付けるなどのビジネスロジックが記述可能です。

実装内容をテストするには、ダッシュボードまたは Stripe CLI を使用してイベントをモニタリングします。本番環境では、Webhook エンドポイントを設定して適切なイベントタイプに登録します。STRIPE_WEBHOOK_SECRET キーが不明な場合は、ダッシュボードで Webhook をクリックして表示します。

テスト

決済ボタンが機能することをテストするには、次の手順を実行します。

  1. 決済ボタンをクリックすると、Stripe Checkout 支払いフォームにリダイレクトされます。
  2. のテストカード番号、3 桁のセキュリティコード、将来の有効期限日、および任意の有効な郵便番号を入力します。
  3. 支払う をタップします。
  4. checkout.session.completed Webhook が起動し、Stripe が取引についてサーバーに通知します。リダイレクトによってアプリへと戻されます。

オプションLemon Squeezy を使用したアプリ内購入

参照情報

  • 割引を追加する
  • 税金を徴収する
このページはお役に立ちましたか。
はいいいえ
お困りのことがございましたら 、サポートにお問い合わせください。
早期アクセスプログラムにご参加ください。
変更ログをご覧ください。
ご不明な点がございましたら、お問い合わせください。
LLM ですか?llms.txt を読んでください。
Powered by Markdoc