首页 > php框架 > Laravel > 正文

laravel怎么使用Cashier处理Stripe或Paddle的订阅支付_laravel Cashier Stripe/Paddle订阅支付方法

裘德小鎮的故事
发布: 2025-10-23 08:33:02
原创
328人浏览过
Laravel Cashier 支持 Stripe 和 Paddle,通过 Billable trait 实现订阅管理,需安装对应包并配置 API 凭据,创建订阅时引用价格 ID 或计划 ID,支持试用期、发票生成与 webhook 事件处理,简化了支付集成流程。

laravel怎么使用cashier处理stripe或paddle的订阅支付_laravel cashier stripe/paddle订阅支付方法

Laravel Cashier 提供了一套简洁的接口来处理订阅支付服务,支持 Stripe 和 Paddle 两种主流支付网关。通过 Cashier,你可以轻松实现创建订阅、管理账单周期、处理试用期、发票生成等常见功能。以下是使用 Laravel Cashier 处理 Stripe 或 Paddle 订阅支付的具体方法。

安装与配置 Cashier

根据你使用的支付平台选择对应的安装方式:

  • 对于 Stripe: 运行 composer require laravel/cashier,然后发布迁移文件并运行迁移:
    php artisan cashier:install。确保在 User 模型中使用 Billable trait。
  • 对于 Paddle: 使用 composer require laravel/cashier-paddle,同样执行 php artisan cashier-paddle:install 来生成必要的数据库字段,并在用户模型中引入 Billable

接着在 .env 文件中设置对应平台的 API 凭据:

# Stripe
STRIPE_KEY=your-stripe-public-key
STRIPE_SECRET=your-stripe-secret-key
<h1>或者 Paddle</h1><p>PADDLE_VENDOR_ID=your-vendor-id
PADDLE_VENDOR_AUTH_CODE=your-auth-code
PADDLE_SANDBOX=true # 开发环境建议开启沙箱</p>
登录后复制

创建订阅计划与启动用户订阅

Stripe 和 Paddle 的定价模式略有不同,但 Cashier 封装了大部分逻辑。

  • Stripe: 需提前在 Stripe 控制台创建价格(Price),然后在代码中引用该价格 ID 启动订阅。
    例如:
    $user-&gt;newSubscription('default', 'price_monthly')-&gt;create($paymentMethod);
  • Paddle: 可直接使用预设的订阅计划 ID(如 12345)或套餐链接 ID 启动订阅:
    $user-&gt;newSubscription('default', 12345)-&gt;create();

如果需要试用期,添加 trialDays(7) 方法即可:

AppMall应用商店
AppMall应用商店

AI应用商店,提供即时交付、按需付费的人工智能应用服务

AppMall应用商店56
查看详情 AppMall应用商店
$user-&gt;newSubscription('pro', 'price_monthly')-&gt;trialDays(7)-&gt;create($paymentMethod);

处理订阅状态与页面跳转

Paddle 会自动跳转到其支付页面完成交易,而 Stripe 支持多种支付方式(包括信用卡、SEPA 等),通常结合 Payment Intents API 在前端收集支付方式后再提交。

  • 订阅成功后,Cashier 会将相关信息存入数据库中的 subscriptions 表。
  • 可通过 $user-&gt;subscribed('default') 判断用户是否处于活跃订阅状态。
  • 检查是否在试用期:$user-&gt;subscription('default')-&gt;onTrial()
  • 取消订阅:$user-&gt;subscription('default')-&gt;cancel();,还可调用 cancelNow() 立即终止。

发票与 webhook 处理

Cashier 自动记录每次付款生成的发票,可通过以下方式获取:

$invoices = $user-&gt;invoices();

对于异步事件(如支付失败、订阅续订、用户取消),需配置 webhook 接收通知:

  • Stripe: 设置 webhook 路由并使用 cashier:webhook 命令验证签名。
  • Paddle: 配置 Paddle 后台的 Webhook URL,Cashier 会自动验证请求来源并触发相应事件。

你可以监听 Cashier 提供的事件,如 InvoicePaidSubscriptionCancelled 等,进行自定义逻辑处理。

基本上就这些,Laravel Cashier 极大简化了订阅系统的开发流程,只要按文档配置好凭证和模型,就能快速上线稳定的付费功能。

以上就是laravel怎么使用Cashier处理Stripe或Paddle的订阅支付_laravel Cashier Stripe/Paddle订阅支付方法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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