0

0

Laravel怎么集成微信支付_Laravel使用EasyWeChat插件【必备】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-09 05:19:06

|

442人浏览过

|

来源于php中文网

原创

EasyWeChat v6与v5差异大,新项目必须用v6;需手动传配置、正确处理prepay_id路径、规范JSAPI参数、严格验签回调、结合异步通知与主动查单防丢,证书须无BOM且为绝对路径。

laravel怎么集成微信支付_laravel使用easywechat插件【必备】

EasyWeChat 版本选错直接导致支付失败

Laravel 集成微信支付时,overtrue/wechat(即 EasyWeChat)的 v5 和 v6 行为差异极大,v6 强制要求使用 HttpClient 实现,且签名逻辑、参数结构、回调验签方式全变了。很多教程照搬旧版代码,结果 app.pay()->unifiedOrder()Invalid signature 或空响应。

实操建议:

  • v5 仍支持 Laravel 5.8–8.x,但已停止维护;新项目必须用 v6(overtrue/wechat:^6.0
  • v6 不再自动读取 config/wechat.php,需手动传入配置数组或使用 WeChat::officialAccount() 等工厂方法
  • 沙箱环境调试时,v6 的 useSandbox(true) 必须在实例化后调用,不能写在配置里
  • 微信返回的 prepay_id 在 v6 中藏在 $result['response']['prepay_id'] 下,不是顶层字段

Laravel 中如何安全传参给前端发起 JSAPI 支付

很多人把 appIdtimeStampnonceStrpackagesignTypepaySign 全部从后端拼好再返回 JSON,结果前端调 WXJSSDK.chooseWXPay() 时提示“参数错误”——问题常出在 package 值没按微信规范转义,或 timeStamp 是字符串而非整数秒。

实操建议:

  • package 字段值必须是 prepay_id=xxx,不能带空格、换行或额外引号
  • timeStamp 必须是 (int) time(),不能是 Carbon::now()->timestamp(可能带毫秒)
  • paySign 生成前,所有参与签名的字段必须按字典序排序,且 package 的值不能 URL 编码(EasyWeChat v6 内部已处理,勿二次 encode)
  • 别把 key(商户 API 密钥)暴露到前端,签名必须 100% 在服务端完成

微信支付回调验签失败的三个高频原因

收到微信 POST 回调后,$app->payment->handleNotify() 返回空或抛出 InvalidSignatureException,不是证书问题就是数据解析错了。v6 默认只接受 application/xml,而有些 Nginx 或 CDN 会把 POST body 转成 application/x-www-form-urlencoded

实操建议:

  • Laravel 中需禁用默认的表单请求解析:在中间件里加 if (request()->isMethod('POST') && request()->header('Content-Type') === 'application/xml') { $content = file_get_contents('php://input'); }
  • v6 的 handleNotify() 默认会自动验签并更新订单状态,若需自定义逻辑,应传 false 关闭自动处理:$app->payment->handleNotify($callback, false)
  • 验签失败时先 dump file_get_contents('php://input'),确认是否为空或被截断——常见于 Nginx 的 client_max_body_size 过小
  • 证书路径必须是绝对路径,ssl_cerssl_key 要对应微信商户平台下载的 apiclient_cert.pemapiclient_key.pem,不能用 .p12

异步通知与主动查询订单状态怎么配合才不丢单

微信回调可能超时、重复或丢失,只依赖 handleNotify() 更新订单状态极易造成“用户付了钱,系统没记账”。但也不能每笔都轮询查,成本高还可能触发风控。

实操建议:

  • 回调成功后,立即记录原始 XML 到数据库(字段如 notify_rawnotify_at),哪怕只是存个日志表,方便事后对账
  • 对“通知未到达”的订单,启用延迟队列(如 Laravel Horizon)在 5 分钟后查一次 $app->payment->find($orderNo),最多重试 3 次
  • 查单接口返回 trade_state=NOTPAYCLOSED 时,不要直接标记失败——可能是用户中途取消,得结合 return_coderesult_code 综合判断
  • 微信侧的 out_trade_no 必须全局唯一,Laravel 中建议用 Str::uuid()->toString() 或时间戳+随机数生成,避免并发重复

最麻烦的其实是证书和签名链——微信的 SHA256withRSA 和 EasyWeChat v6 的 OpenSSL 调用方式耦合极深,稍有不慎就卡在 openssl_sign(): supplied key param cannot be coerced into a private key,这时候别急着换包,先检查 pem 文件有没有被编辑器悄悄转成 UTF-8 BOM。事情说清了就结束

相关文章

微信app下载
微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

326

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

283

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

497

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

377

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

107

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

74

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

234

2023.07.27

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

67

2026.02.06

热门下载

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

精品课程

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

共137课时 | 11.3万人学习

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号