在应用内付款期间保存付款详情
在移动应用中保存付款过程中的付款详情。
用 Payment Intents API 保存购物时输入的付款详情。有几个用例:
- 对客户的网上订单扣款并存储支付信息,用于以后的购物。
- 发起一系列经常性付款中的第一笔付款。
- 收取押金并存储详情,便于以后收取完整金额。
有卡交易
有卡交易(例如通过 Stripe Terminal 支付)使用不同的流程来保存支付方式。有关详情,请查看 Terminal 文档。
合规
在保存客户的支付详情时,您需要负责遵守所有适用的法律、法规和卡组织规则。如果您想要保存客户的支付方式以供将来使用,则通常会适用于这些要求,例如在结账流程中向他们显示客户的支付方式以供将来购物使用,或者在他们不主动使用您的网站或应用程序时向他们扣款。在您的网站或应用程序中添加条款,说明您计划如何保存支付方式的详细信息,并允许客户选择加入。
保存支付方式后,您只能将它用于条款中包含的特定使用量。要在客户离线时对某种支付方式扣款并将其保存为可供未来购物时选择的选项,请务必收集客户对这一特定用途的明确同意。例如,包含“保存我的支付方式以供未来使用”复选框以收集用户同意书。
要想在他们离线时收款,请确保您的条款中包含以下内容:
- 客户同意您代其对指定的交易发起一次或一系列付款。
- 预期的付款时间和频率(例如,收款是计划的分期付款、订阅付款还是计划外充值)。
- 如何确定付款金额。
- 如果支付方式是用于支付订阅服务,那即同意您的取消政策。
请务必让客户书面同意这些条款并做好记录。
设置 Stripe服务器端客户端
首先,您需要一个 Stripe 账户。立即注册。
服务器端
该集成要求您的服务器上的端点与 Stripe API 通信。用我们的官方库从您的应用程序访问 Stripe API:
客户端
Stripe iOS SDK 是开源的,有完整的文档,并且与支持 iOS 13 或更高版本操作系统的应用程序兼容。
添加端点服务器端
注意
要在创建 PaymentIntent 之前显示 PaymentSheet,请参阅收集支付详情后再创建 Intent。
该集成使用三个 Stripe API 对象:
PaymentIntent:Stripe 用它来表示您从客户收款的意图,跟踪您的扣款尝试及整个过程中付款状态的变化情况。
Customer:要为将来的付款设置支付方式,就必须将它绑定到 Customer。当客户在您的公司创建账户时,创建 Customer 对象。如果您的客户以访客身份付款,则可以在付款前创建个 Customer 对象,然后再将它关联到您自己内部的客户账户表示。
Customer Ephemeral Key:Customer 对象的信息属于敏感信息,无法直接从应用中检索。临时密钥授予 SDK 对客户的临时访问权限。
出于安全原因,您的应用无法创建这些对象。相反,在服务器上会添加一个端点,其功能如下:
- 检索 Customer,或新建一个。
- 为 Customer 创建一个 Ephemeral Key。
- 创建 PaymentIntent,设置好 amount、currency 和 customer, setup_future_usage 。您还可以选择包含
automatic_
参数。默认情况下,Stripe 会在最新版的 API 中启用其功能。payment_ methods - 将 Payment Intent 的客户端私钥、Ephemeral Key 的
secret
以及 Customer 的 id 和您的公钥返回到您的应用程序。
注意
移动端 Payment Element 仅支持拥有卡和美国银行账户的 setup_
。
在结账过程中显示给客户的支付方式也包含在 PaymentIntent 中。您可以让 Stripe 从管理平台设置中提取支付方式,也可以手动列出它们。无论选择哪种方式,都要知道在 PaymentIntent 中传递的货币会过滤显示给客户的支付方式。例如,如果您在 PaymentIntent 中传递 eur
,并且在管理平台中启用了 OXXO,则不会向客户显示 OXXO,因为 OXXO 不支持 eur
支付。
除非您的集成需要基于代码的选项来提供支付方式,否则 Stripe 建议使用自动选项。这是因为 Stripe 会评估货币、支付方式限制和其他参数,以确定支持的支付方式列表。优先显示可提高转化率且与货币和客户所在地最相关的支付方式。
收集付款详情客户端
要在结账屏幕上显示移动 Payment Element,您必须确保:
- 显示客户正在购买的产品以及总金额
- 用 Address Element 从客户那里收集所需的配送信息
- 添加结账按钮以显示 Stripe 的 UI
如果 PaymentSheetResult
是 .
,则通知用户(例如,显示订单确认界面)。
将 allowsDelayedPaymentMethods
设置为 true,以允许延迟通知型支付方式,例如美国银行账户。对于这些支付方式,只有当 PaymentSheet
完成后才能知道最终的付款状态是成功还是失败。如果您支持这些类型的支付方式,请告知客户他们的订单已被确认,并且仅在付款成功时履行订单(例如,为他们安排发货)。
设置返回URL客户端
客户可能会离开您的应用来验证(例如,去 Safari 或他们的网银应用)。若允许他们在验证后自动返回到您的应用,配置一个自定义页面内跳转协议 (URL Scheme),并设置您的应用程序代理将 URL 转发到 SDK。Stripe 不支持通用链接。
此外,将您的 PaymentSheet.Configuration 对象上的 returnURL 设置到您的应用的 URL。
var configuration = PaymentSheet.Configuration() configuration.returnURL = "your-app://stripe-redirect"
处理付款后事件服务器端
付款完成时,Stripe 会发送一个 payment_intent.succeeded 事件。使用 管理平台 Webhook 工具、或按照 Webhook 指南来接收这些事件并运行操作,例如,向客户发送订单确认邮件、在数据库中记录订单,或启动配送流程。
侦听这些事件,而不是等待客户端回调。在客户端,客户可能会在执行回调之前关闭浏览器窗口或退出应用程序,并且恶意客户端可能会操纵响应。设置您的集成来侦听异步事件,这样才能用单一集成用用接受不同类型的支付方式。
除了处理 payment_
事件外,建议在使用 Payment Element 收款时也处理其他的这些事件:
事件 | 描述 | 操作 |
---|---|---|
payment_intent.succeeded | 客户成功完成付款时发送。 | 向客户发送订单确认通知,并履行他们的订单。 |
payment_intent.processing | 当客户成功发起付款但并未完成时发送。当客户发起银行借记时,通常会发送此事件。之后将会出现 payment_ 或 payment_ 事件。 | 向客户发送订单确认,告知他们的付款正等待处理。对于数字商品,您可能想先履行订单,然后再等付款完成。 |
payment_intent.payment_failed | 在客户尝试付款但付款失败时发送。 | 如果一笔付款从 processing 变为 payment_ ,则让客户再尝试一次。 |
以后对保存的 Payment Method 扣款服务器端
合规
保存客户的支付详情时,您有责任遵守所有适用的法律、法规和卡组织规则。向您的最终客户呈现之前用过的支付方式以供未来购物使用时,确保您所列出的支付方式已从客户那里收集保存支付方式详情以供将来具体使用的同意书。对于绑定到客户的支付方式,要区分哪些可以哪些不可以作为保存的支付方式供未来购物使用,请使用 allow_redisplay 参数。
准备在会话外对客户扣款时,使用 Customer 和 PaymentMethod ID 创建一个 PaymentIntent。要找到扣款的支付方式,列出与您的客户关联的支付方式。该例中列出了银行卡,但您可以列出任意受支持的 type。
当您有 Customer 和 PaymentMethod ID 时,创建一个包含付款金额和货币的 PaymentIntent。设置几个其他参数来进行会话外付款:
- 将 off_session 设置为
true
,以指示客户其在尝试付款时并不在您的结账流程中,并且无法完成合作伙伴(如发卡行、银行或其他支付机构)提出的身份验证请求。如果在您的结账流程中,合作伙伴要求进行验证,Stripe 将使用之前的会话内交易中的客户信息请求豁免。如果不满足豁免条件,PaymentIntent 可能会抛出一个错误。 - 将 PaymentIntent 的 confirm 属性的值设置为
true
,这样就会在创建 PaymentIntent 时立即进行确认。 - 将 payment_method 设置为 PaymentMethod 的 ID,并将 customer 设置为 Customer 的 ID。