0

0

微信卡券回调PHP怎么接收_处理卡券事件推送参数方法【详解】

看不見的法師

看不見的法師

发布时间:2026-01-03 22:03:07

|

783人浏览过

|

来源于php中文网

原创

必须用 file_get_contents('php://input') 获取原始 XML 数据,再结合 $_GET['msg_signature']、$_GET['timestamp']、$_GET['nonce'] 及 Token 按指定顺序 SHA1 签名验证,通过后方可解析 XML 提取 Event、CardId、UserCardCode 等字段。

微信卡券回调php怎么接收_处理卡券事件推送参数方法【详解】

微信卡券事件推送的原始数据怎么获取

微信服务器向你的 PHP 后端推送卡券事件(如用户领券、核销、删除)时,**不会以 $_POST$_GET 形式传递参数**,而是通过 HTTP POST 以 XML 格式直接发送原始 body 数据。这意味着:$_POST 始终为空,file_get_contents('php://input') 是唯一可靠入口。

  • 必须用 file_get_contents('php://input') 读取原始请求体,不能依赖 $_POST
  • 微信签名验证前,**不能先调用 simplexml_load_string() 或其他解析操作**,否则可能因非法 XML 导致脚本崩溃,失去验证机会
  • 若使用框架(如 Laravel、ThinkPHP),需确认是否自动解析了请求体;Laravel 中应使用 $request->getContent(),而非 $request->all()

如何正确验证微信推送签名

微信要求你校验 msg_signaturetimestampnonce 和原始 XML 内容四者联合签名,缺一不可。失败即说明不是微信官方推送,应直接丢弃。

  • 从 URL 参数中提取三个关键值:$_GET['msg_signature']$_GET['timestamp']$_GET['nonce']
  • 原始 XML 数据(来自 php://input)必须**原样参与签名计算**,不能提前 trim()htmlspecialchars() 或转码,否则签名不匹配
  • 签名算法是 SHA1,拼接顺序为:token . timestamp . nonce . xml(注意:不是按字母序,也不是含空格)
  • PHP 示例中务必使用 sha1(),而非 md5()hash('sha256', ...)
function checkSignature($xml, $msgSig, $timestamp, $nonce, $token) {
    $tmpArr = array($token, $timestamp, $nonce, $xml);
    sort($tmpArr, SORT_STRING);
    $tmpStr = implode($tmpArr);
    return sha1($tmpStr) === $msgSig;
}

解析 XML 后如何提取关键卡券事件字段

签名通过后才能安全解析 XML。微信卡券事件的 结构固定,但不同事件(user_get_carduser_consume_carduser_delete_card)携带的子节点差异大,需按 EventCardId 区分处理逻辑。

  • Event 字段决定事件类型,值为字符串,如 user_get_card(领券)、user_consume_card(核销)
  • CardId 是卡券唯一 ID,用于查库关联优惠规则;OrderId 仅在核销事件中存在,对应商户订单号
  • UserCardCode 是用户所持该卡的唯一编码,每次领券生成一个新码,**不是用户 openid** —— 核销时必须用它查卡状态
  • 注意 IsGiveByFriend(是否他人转赠)和 FriendUserName(转赠人 openid),影响权益归属判断
$xml = file_get_contents('php://input');
$obj = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA);
$event = (string)$obj->Event;
$cardId = (string)$obj->CardId;
$userCardCode = (string)$obj->UserCardCode;

常见失败原因和调试建议

线上收不到推送、验签失败、解析出空值——90% 源于这几个点。

Pictory
Pictory

AI视频制作工具,可以通过长内容中制作简短视频

下载

立即学习PHP免费学习笔记(深入)”;

  • 服务器返回非 200 状态码(如 500、404、301),或响应体含多余空格/UTF-8 BOM,微信会判定回调失败并停止推送
  • PHP 开启了 always_populate_raw_post_data(已废弃)或设置了 enable_post_data_reading = Off,导致 php://input 为空
  • 未在微信公众号后台「卡券功能」→「事件通知」中开启对应事件,或填写的 URL 域名未备案 / 未配好 HTTPS(微信强制要求)
  • 本地调试时用微信「开发者工具」模拟推送,但没把 msg_signature 等参数拼到 URL 上,造成验签必然失败

最稳妥的调试方式:在验签前先记录原始 php://input$_GET 到日志文件,再比对签名逻辑 —— 卡券回调的容错极低,差一个字符就全盘失效。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2212

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1470

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1373

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

951

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1412

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1233

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1443

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.06

热门下载

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

精品课程

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

共137课时 | 8.4万人学习

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

共6课时 | 6.9万人学习

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

共13课时 | 0.8万人学习

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

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