0

0

从 Stripe 预构建结账获取客户数据

霞舞

霞舞

发布时间:2025-09-30 21:06:02

|

1001人浏览过

|

来源于php中文网

原创

从 stripe 预构建结账获取客户数据

本文介绍了如何在使用 Stripe 预构建结账集成时获取客户数据(特别是 Customer ID),以便将其存储在数据库中。由于预构建结账会自动处理客户创建,本文将重点介绍两种方法:在创建 Checkout Session 时传入已存在的 Customer ID,或者通过 Webhooks 监听 checkout.session.completed 事件来获取 Customer ID。

方法一:在创建 Checkout Session 时传入 Customer ID

如果您的应用已经存在客户信息,您可以直接在创建 Checkout Session 时传入 Customer ID。这样,Stripe 就不会创建新的 Customer 对象,而是使用您提供的现有 Customer 对象。

以下是示例代码:

\Stripe\Stripe::setApiKey('sk_test_51J...........esLwtMQx7IXNxp00epljtC43');

header('Content-Type: application/json');

$YOUR_DOMAIN = 'mydomain.com';

// 假设您已经有了 Customer ID
$customer_id = 'cus_XXXXXXXXXXXXXXX';

$checkout_session = \Stripe\Checkout\Session::create([
    'payment_method_types' => ['card'],
    'line_items' => [[
      'price'=>"price_1Jt.....vImqj",
      'quantity'=>1,
    ]],
    'mode' => 'subscription',
    'success_url' => $YOUR_DOMAIN . '/success.php',
    'cancel_url' => $YOUR_DOMAIN . '/cancel.html',
    'customer' => $customer_id, // 传入 Customer ID
  ]);

注意事项:

  • 确保 $customer_id 变量包含有效的 Stripe Customer ID。
  • 如果提供的 Customer ID 不存在,Stripe 将抛出错误。

方法二:使用 Webhooks 监听 checkout.session.completed 事件

如果您的应用在 Checkout Session 创建之前没有客户信息,Stripe 会根据用户在结账过程中提供的信息自动创建 Customer 对象。 在这种情况下,您需要设置 Webhooks 来监听 checkout.session.completed 事件,并在该事件触发时获取 Customer ID。

步骤 1:配置 Webhook 端点

首先,您需要在您的服务器上创建一个 Webhook 端点,用于接收 Stripe 发送的事件。 您可以在 Stripe Dashboard 中配置 Webhook 端点 URL。

知了zKnown
知了zKnown

知了zKnown:致力于信息降噪 / 阅读提效的个人知识助手。

下载

步骤 2:监听 checkout.session.completed 事件

在 Webhook 端点中,您需要验证 Stripe 发送的事件,并提取 checkout.session.completed 事件中的 Customer ID。

以下是一个 PHP 示例:

safeLoad();

\Stripe\Stripe::setApiKey($_ENV['STRIPE_SECRET_KEY']);

// Use a raw post body, since the Webhook endpoint expects raw content
$payload = @file_get_contents('php://input');
$sig_header = $_SERVER['HTTP_STRIPE_SIGNATURE'];
$endpoint_secret = $_ENV['STRIPE_WEBHOOK_SECRET'];

try {
    $event = \Stripe\Webhook::constructEvent(
        $payload, $sig_header, $endpoint_secret
    );
} catch(\UnexpectedValueException $e) {
    // Invalid payload
    http_response_code(400);
    exit();
} catch(\Stripe\Exception\SignatureVerificationException $e) {
    // Invalid signature
    http_response_code(400);
    exit();
}

// Handle the checkout.session.completed event
if ($event->type == 'checkout.session.completed') {
  $session = $event->data->object;

  // 获取 Customer ID
  $customer_id = $session->customer;

  // 将 Customer ID 存储到数据库
  // ...

  http_response_code(200);
}

注意事项:

  • 务必验证 Stripe 发送的 Webhook 事件的签名,以确保事件的真实性。 使用 Stripe 提供的 SDK 可以方便地进行签名验证。
  • $_ENV['STRIPE_SECRET_KEY'] 和 $_ENV['STRIPE_WEBHOOK_SECRET'] 应该从环境变量中读取,而不是硬编码在代码中。
  • 请根据您的数据库结构和需求,修改示例代码中的数据库存储部分。

总结:

通过以上两种方法,您可以方便地从 Stripe 预构建结账中获取客户数据,并将其集成到您的应用中。 选择哪种方法取决于您的具体需求和应用架构。 如果您的应用已经存在客户信息,建议使用第一种方法,直接在创建 Checkout Session 时传入 Customer ID。 如果您的应用在 Checkout Session 创建之前没有客户信息,则需要使用 Webhooks 监听 checkout.session.completed 事件来获取 Customer ID。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

315

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

749

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

93

2025.08.19

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

358

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2082

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

349

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

256

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.10.09

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

0

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号