3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Stripe APIバージョンを`2023-08-16`以降に変更して、Stripe Elements / Payment Intentにエラーが発生した場合の対処法

Posted at

ダッシュボード上の操作やSDKまたはAPIリクエストのヘッダーなどで、StripeのAPIバージョンを変更した場合、Stripe Elementsを利用した決済フローで以下のエラーが発生することがあります。

Uncaught (in promise) IntegrationError: stripe.confirmPayment(): the confirmParams.return_url argument is required unless passing `redirect: 'if_required'

アプリケーションコードの変更がないにもかかわらず、このエラーが発生した場合は、アプリケーションが利用しているStripe APIのバージョンが2023-08-16またはそれよりも新しいバージョンに切り替わっている可能性があります。

Stripe APIのメジャーアップデート

Stripeは定期的に後方互換性のないAPIアップデート(メジャーアップデート)を実施します。

これは多様化する決済手段への対応や、新しい決済取引に関する規制への対応、より便利でシンプルなコードでの開発を実現するためなど、様々な理由があります。

APIのメジャーアップデートを確認する方法

「どのような変更が、いつ・どのバージョンで行われたか」はStripeのドキュメントから確認できます。

「新しいパラメータの追加」など、後方互換性を維持したアップデートについては、以下のドキュメントにて紹介しています。

メジャーアップデートの適応はダッシュボードの操作かSDKおよびAPIの設定を変更して実施

後方互換性のないAPIアップデートが自動で適応されることはありません

Stripeダッシュボードで「APIバージョンのアップグレード」操作を行うことで、デフォルトのAPIバージョンを変更できます。

スクリーンショット 2023-09-01 14.10.55.png

また、SDKやAPIのリクエストヘッダーを利用して、特定のバージョンのAPIを利用することも可能です。

const stripe = new Stripe('sk_test_xxx', { apiVersion: '2022-11-15' })
curl https://api.stripe.com/v1/customers \
  -u sk_test_your_key: \
  -H "Stripe-Version: 2023-08-16"

もし意図せずにAPIバージョンがアップグレードされている場合、72時間以内であれば、以前のバージョンにロールバックできます。

APIバージョン2023-08-16での変更点

APIバージョン2023-08-16では、Payment Intent / Setup Intentを中心にアップデートが行われました。

このバージョンからは、「動的な決済手段を使用する」オプションがデフォルトで有効となります。

PaymentIntents and SetupIntents now have automatic_payment_methods enabled by default, which allows you to configure payment method settings from the Dashboard—no code required. The previous default was to accept only card payments when both payment_method_types and automatic_payment_methods were not specified. For more information, view the upgrade guide.
https://stripe.com/docs/upgrades#2023-08-16

冒頭で紹介しているエラーは、この「動的な決済手段を使用する」オプションが、APIバージョンのアップグレードによって有効化された際に発生することがあります。

動的な決済手段とは

Stripeは世界で利用されている様々な決済手段をサポートしています。

しかし決済手段によっては、「対応通貨」や「最低利用可能金額」「顧客(Customer)データの有無」など様々な利用条件が発生します。

例えば次のコードでは、「全世界でクレジットカード決済を受け付ける」「ユーロの取引ではPayPalも利用できるようにする」「日本円では、コンビニ支払いもサポートする」の3条件を設定しています。

  const orderAmount = req.body.amount;
  const orderCurrency = req.body.currency;

  const paymentMethodTypes = ["card"];
  switch(currency) {
    case "jpy":
      if (orderAmount >= 120 && orderAmount <= 300000) {
        paymentMethodTypes.push("konbini");
      }
      break;
    case "eur":
      paymentMethodTypes.push("paypal");
      break;
    default:
      break;
  }
  const paymentIntent = await stripe.paymentIntents.create({
    amount: orderAmount,
    currency: orderCurrency,
    payment_method_types: paymentMethodTypes,
  });

この方法では、「Stripeが新しい決済手段のサポートを開始した場合」や「越境ECなどで、新しい通貨・地域での決済の受付を開始する場合」に、コードの変更とアプリケーションのデプロイ作業が発生します。

「動的な決済手段を使用する」オプションを有効化すると、「どの決済手段を顧客に提示すべきか」の判断を、Stripeダッシュボード上の設定に任せることができます。

スクリーンショット 2023-09-01 13.29.03.png

アプリケーションのソースコードからも、決済手段に関する実装を削除できます。

  const orderAmount = req.body.amount;
  const orderCurrency = req.body.currency;

-  const paymentMethodTypes = ["card"];
-  switch(currency) {
-    case "jpy":
-      if (orderAmount >= 120 && orderAmount <= 300000) {
-        paymentMethodTypes.push("konbini");
-      }
-      break;
-    case "eur":
-      paymentMethodTypes.push("paypal");
-      break;
-    default:
-      break;
-  }
  const paymentIntent = await stripe.paymentIntents.create({
    amount: orderAmount,
    currency: orderCurrency,
-    payment_method_types: paymentMethodTypes,
  });

APIバージョンが2022-11-15以前の場合、この機能を利用するには、automatic_payment_methodsパラメータを明示的に設定する必要がありました。

  const orderAmount = req.body.amount;
  const orderCurrency = req.body.currency;

  const paymentIntent = await stripe.paymentIntents.create({
    amount: orderAmount,
    currency: orderCurrency,
+    automatic_payment_methods: {
+      enabled: true
+    },
  });

APIバージョン2023-08-16以降は、automatic_payment_methods[enabled]falseにしていない場合、「動的な決済手段を使用する」オプションが有効となります。

confirmPaymentconfirmSetupがエラーになる場合の対応方法

APIバージョン2023-08-16以降では、Payment Intent / Setup Intentを作成する際に、以下のどちらかを行う必要があります。

  • confirmPaymentconfirmSetupの第二引数に、confirmParams[return_url]を設定する
  • automatic_payment_methods[allow_redirects]=neverを設定し、リダイレクトを必要とする決済を除外する
                <form onSubmit={async e => {
                    e.preventDefault()
                    if (!stripe || !elements) return
                    await stripe.confirmPayment({
                        elements,
+                        confirmParams: {
+                            return_url: 'http://localhost:3001'
+                        }                       
                    })
                }}>
                    <PaymentElement />
                    <button type='submit'>Pay</button>
                </form>

これにより、Stripe側が決済フォームに「リダイレクトを必要とする決済手段」を表示した場合に、適切なURLへリダイレクトさせることができます。

各言語ごとの対応方法については、以下のドキュメントをご確認ください。

デフォルトとしてダッシュボードで決済手段を管理する
https://stripe.com/docs/upgrades/manage-payment-methods

「動的な決済手段」に切り替えることで、何が起きるか

この機能を有効化すると、金額・通貨などを元に顧客に提示する決済手段を動的に変更できます。

また、複数の決済手段を表示する際の表示順序についても、Stripeがもつ決済データを元に最適化された順番で表示できます。

スクリーンショット 2023-09-01 13.49.20.png
https://stripe.com/docs/payments/payment-element

金額や通貨・その他の決済設定によって、どの決済手段が表示されるかや、「なぜこの決済手段は表示されないか」を確認するツールもダッシュボードにて提供しています。

スクリーンショット 2023-09-01 13.47.27.png
https://dashboard.stripe.com/test/settings/payment_methods/review

Stripe Docsで紹介している、いくつかのベータ機能を紹介します。

決済手段の設定を複数用意する

「サブスクリプションでは、クレジットカード決済のみにしたい」など、Stripeが判断する条件とは別の条件で表示する決済手段を設定することも可能になります。

この機能を利用すると、Payment IntentやCheckoutのセッション作成時に、設定IDを渡すことで個別に設定した条件で決済手段を表示できます。

await stripe.checkout.sessions.create({
  mode: 'payment',
  line_items: [
    {
      price: '{{PRICE_ID}}',
      quantity: 1,
    },
  ],
  success_url: 'https://example.com/success',
  cancel_url: 'https://example.com/cancel',
  currency: 'usd',
+  payment_method_configuration: 'pmc_234',
});

決済手段のA/Bテスト

複数の決済手段を顧客に提供した場合の購入完了率(コンバージョン率)やStripeに支払う手数料・不審請求の申立て率などをA/Bテストすることができます。

アップデートされ続ける「最適化された決済体験」をStripeで手軽に手に入れよう

Stripeでは、今回のように後方互換性を持たないバージョンのAPIを、定期的にリリースします。

しかし新しいバージョンのAPIを利用することで、より少ないコード・少ない保守作業で、Stripeがアップデートし続ける「最適化された決済体験」を顧客に提示し続けることができます。

まだStripeを触ったことのない方は、Stripeが用意するサンプル集などを利用して、ぜひStripeの決済体験をお試しください。

関連記事

3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?