首页 > php框架 > Laravel > 正文

Laravel如何集成第三方支付网关_Laravel支付接口对接实现

穿越時空
发布: 2025-11-24 04:25:35
原创
308人浏览过
Laravel集成第三方支付需选合适扩展包如overtrue/laravel-pay,配置支付宝或微信支付参数,创建支付路由与控制器,通过verify验证异步通知并处理订单,返回success响应确保交易安全。

laravel如何集成第三方支付网关_laravel支付接口对接实现

Laravel 集成第三方支付网关并不复杂,只要理解支付流程并选择合适的扩展包或手动对接 API 即可。常见的支付平台如支付宝微信支付、PayPal、Stripe 等都可以通过官方 SDK 或社区封装的包在 Laravel 中实现。以下是具体实现方式和步骤。

1. 选择支付网关与对应扩展包

为加快开发速度,推荐使用成熟的 Laravel 支付包。例如:

  • overtrue/laravel-pay:支持支付宝和微信支付,兼容 Laravel 服务容器,使用简单。
  • mollie/laravel-cashier-mollie:适用于欧洲常用支付网关 Mollie。
  • laravel/cashier-paddle:集成 Paddle 支付,适合 SaaS 应用。

overtrue/laravel-pay 为例,安装命令如下:

composer require "overtrue/laravel-pay:^4.0"

配置服务提供者(Laravel 9+ 可自动发现):

'providers' => [ Overtrue\LaravelPay\ServiceProvider::class, ], 'aliases' => [ 'Pay' => Overtrue\LaravelPay\Facade::class, ]

2. 配置支付参数

创建配置文件 config/pay.php,填写支付宝或微信支付所需信息:

return [ 'alipay' => [ 'app_id' => env('ALIAPP_APP_ID'), 'notify_url' => 'https://your-domain.com/payment/alipay/notify', 'return_url' => 'https://your-domain.com/payment/return', 'ali_public_key' => '填入支付宝公钥', 'private_key' => '填入应用私钥', 'log' => [ 'file' => storage_path('logs/alipay.log'), 'level' => 'debug' ], 'mode' => 'normal', // 'dev' 或 'normal' ], 'wechat' => [ 'app_id' => env('WECHAT_APPID'), 'mch_id' => env('WECHAT_MCH_ID'), 'key' => env('WECHAT_KEY'), 'notify_url' => 'https://your-domain.com/payment/wechat/notify', 'cert_client' => '/path/to/apiclient_cert.pem', 'cert_key' => '/path/to/apiclient_key.pem', 'log' => [ 'file' => storage_path('logs/wechat_pay.log'), 'level' => 'debug' ], ] ];

将敏感信息写入 .env 文件:

沉浸式翻译
沉浸式翻译

沉浸式翻译:全网口碑炸裂的双语对照网页翻译插件

沉浸式翻译 205
查看详情 沉浸式翻译
ALIAPP_APP_ID=2021XXXXXX WECHAT_APPID=wxXXXXXX WECHAT_MCH_ID=15XXXXXX WECHAT_KEY=your_wechat_api_key

3. 创建支付路由与控制器

routes/web.php 添加支付相关路由:

Route::get('/pay', [PaymentController::class, 'pay']); Route::post('/payment/alipay/notify', [PaymentController::class, 'alipayNotify']); Route::post('/payment/wechat/notify', [PaymentController::class, 'wechatNotify']);

在控制器中发起支付请求:

use Pay; class PaymentController extends Controller { public function pay() { $order = [ 'out_trade_no' => time(), 'total_amount' => '100.00', 'subject' => '测试商品', ]; return Pay::alipay()->web($order); } public function alipayNotify() { $data = Pay::alipay()->verify(); // 验证回调数据 if ($data->trade_status == 'TRADE_SUCCESS') { // 更新订单状态 } return Pay::alipay()->success(); } }

4. 处理异步通知与验证

支付结果必须通过异步通知(notify_url)确认,不能依赖前端跳转。关键点:

  • 收到通知后调用 verify() 方法验证签名防止伪造。
  • 检查订单是否已处理,避免重复发货。
  • 处理成功后返回正确响应(如 Alipay 要求返回 'success')。

微信支付示例:

public function wechatNotify() { $pay = Pay::wechat(); try { $data = $pay->verify(); // 验签 if (isset($data['result_code']) && $data['result_code'] === 'SUCCESS') { // 处理订单逻辑 return $pay->success(); } } catch (\Exception $e) { \Log::error('WeChat Notify Error: ' . $e->getMessage()); } return 'fail'; }

基本上就这些。只要配置准确、验签严谨、异步处理到位,Laravel 对接第三方支付就很稳定。调试时建议开启日志,结合沙箱环境测试完整流程。

以上就是Laravel如何集成第三方支付网关_Laravel支付接口对接实现的详细内容,更多请关注php中文网其它相关文章!

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

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

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

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