Laravel集成第三方支付需选合适扩展包如overtrue/laravel-pay,配置支付宝或微信支付参数,创建支付路由与控制器,通过verify验证异步通知并处理订单,返回success响应确保交易安全。

Laravel 集成第三方支付网关并不复杂,只要理解支付流程并选择合适的扩展包或手动对接 API 即可。常见的支付平台如支付宝、微信支付、PayPal、Stripe 等都可以通过官方 SDK 或社区封装的包在 Laravel 中实现。以下是具体实现方式和步骤。
为加快开发速度,推荐使用成熟的 Laravel 支付包。例如:
以 overtrue/laravel-pay 为例,安装命令如下:
composer require "overtrue/laravel-pay:^4.0"配置服务提供者(Laravel 9+ 可自动发现):
'providers' => [ Overtrue\LaravelPay\ServiceProvider::class, ], 'aliases' => [ 'Pay' => Overtrue\LaravelPay\Facade::class, ]创建配置文件 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 文件:
ALIAPP_APP_ID=2021XXXXXX WECHAT_APPID=wxXXXXXX WECHAT_MCH_ID=15XXXXXX WECHAT_KEY=your_wechat_api_key在 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(); } }支付结果必须通过异步通知(notify_url)确认,不能依赖前端跳转。关键点:
微信支付示例:
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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号