企业微信 php回调模式,老师,我的是微信企业号,开启回调模式一直不行,总提示 请求该url失败...

老师,我的是微信企业号,开启回调模式一直不行,总提示 请求该url失败。

3b7db6df3645509ff3d5450b3cd1aeda.png

我sae代码是

include_once "WXBizMsgCrypt.php";

// 假设企业号在公众平台上设置的参数如下

$encodingAesKey = "JbjgbPVWQICYMGMIFpkMtuPe0TuFbeicyl7EIxk6vrr";

$token = "weixin";

$corpId = "wxbd40366dad36c627";

/*

------------使用示例一:验证回调URL---------------

*企业开启回调模式时,企业号会向验证url发送一个get请求

假设点击验证时,企业收到类似请求:

* GET /cgi-bin/wxpush?msg_signature=5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3&timestamp=1409659589&nonce=263014780&echostr=P9nAzCzyDtyTWESHep1vC5X9xho/qYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp+4RPcs8TgAE7OaBO+FZXvnaqQ==

* HTTP/1.1 Host: qy.weixin.qq.com

接收到该请求时,企业应

1.解析出Get请求的参数,包括消息体签名(msg_signature),时间戳(timestamp),随机数字串(nonce)以及公众平台推送过来的随机加密字符串(echostr),

这一步注意作URL解码。

2.验证消息体签名的正确性

3. 解密出echostr原文,将原文当作Get请求的response,返回给公众平台

第2,3步可以用公众平台提供的库函数VerifyURL来实现。

*/

// $sVerifyMsgSig = HttpUtils.ParseUrl("msg_signature");

$sVerifyMsgSig = "5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3";

// $sVerifyTimeStamp = HttpUtils.ParseUrl("timestamp");

$sVerifyTimeStamp = "1409659589";

// $sVerifyNonce = HttpUtils.ParseUrl("nonce");

$sVerifyNonce = "263014780";

// $sVerifyEchoStr = HttpUtils.ParseUrl("echostr");

$sVerifyEchoStr = "P9nAzCzyDtyTWESHep1vC5X9xho/qYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp+4RPcs8TgAE7OaBO+FZXvnaqQ==";

// 需要返回的明文

$EchoStr = "";

$wxcpt = new WXBizMsgCrypt($token, $encodingAesKey, $corpId);

$errCode = $wxcpt->VerifyURL($sVerifyMsgSig, $sVerifyTimeStamp, $sVerifyNonce, $sVerifyEchoStr, $sEchoStr);

if ($errCode == 0) {

//

// 验证URL成功,将sEchoStr返回

// HttpUtils.SetResponce($sEchoStr);

} else {

print("ERR: " . $errCode . "nn");

}

/*

------------使用示例二:对用户回复的消息解密---------------

用户回复消息或者点击事件响应时,企业会收到回调消息,此消息是经过公众平台加密之后的密文以post形式发送给企业,密文格式请参考官方文档

假设企业收到公众平台的回调消息如下:

POST /cgi-bin/wxpush? msg_signature=477715d11cdb4164915debcba66cb864d751f3e6&timestamp=1409659813&nonce=1372623149 HTTP/1.1

Host: qy.weixin.qq.com

Content-Length: 613

企业收到post请求之后应该

1.解析出url上的参数,包括消息体签名(msg_signature),时间戳(timestamp)以及随机数字串(nonce)

2.验证消息体签名的正确性。

3.将post请求的数据进行xml解析,并将标签的内容进行解密,解密出来的明文即是用户回复消息的明文,明文格式请参考官方文档

第2,3步可以用公众平台提供的库函数DecryptMsg来实现。

*/

// $sReqMsgSig = HttpUtils.ParseUrl("msg_signature");

$sReqMsgSig = "477715d11cdb4164915debcba66cb864d751f3e6";

// $sReqTimeStamp = HttpUtils.ParseUrl("timestamp");

$sReqTimeStamp = "1409659813";

// $sReqNonce = HttpUtils.ParseUrl("nonce");

$sReqNonce = "1372623149";

// post请求的密文数据

// $sReqData = HttpUtils.PostData();

$sReqData = "";

$sMsg = "";  // 解析之后的明文

$errCode = $wxcpt->DecryptMsg($sReqMsgSig, $sReqTimeStamp, $sReqNonce, $sReqData, $sMsg);

if ($errCode == 0) {

// 解密成功,sMsg即为xml格式的明文

// TODO: 对明文的处理

// For example:

$xml = new DOMDocument();

$xml->loadXML($sMsg);

$content = $xml->getElementsByTagName('Content')->item(0)->nodeValue;

print("content: " . $content . "nn");

// ...

// ...

} else {

print("ERR: " . $errCode . "nn");

//exit(-1);

}

/*

------------使用示例三:企业回复用户消息的加密---------------

企业被动回复用户的消息也需要进行加密,并且拼接成密文格式的xml串。

假设企业需要回复用户的明文如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值