微信企业号开发php版1-接口验证

普通模式类似公众号的编辑模式,很简单不再介绍,回调模式类似开发模式,略有不同。

下载模板http://qydev.weixin.qq.com/php.zip

接口文件为sample.php进行如下修改,找到corpId,AK和token自己改写或用模板的。提交sample.php路径后,验证成功。

<?php
//更改第8行corpID,token和encodingAesKey可选用代码里的参数填写
include_once "WXBizMsgCrypt.php";

// 假设企业号在公众平台上设置的参数如下
$encodingAesKey = "jWmYm7qr5nMoAUwZRjGtBxmz3KA1tkAj3ykkR6q2B2C";
$token = "QDG6eK";
$corpId = "xxxxxxxxxxxx";//需要更换


$sVerifyMsgSig =$_GET["msg_signature"]; 
$sVerifyTimeStamp =$_GET["timestamp"]; 
$sVerifyNonce = $_GET["nonce"];
$sVerifyEchoStr = $_GET["echostr"];
// 需要返回的明文
$sEchoStr = "";
$wxcpt = new WXBizMsgCrypt($token, $encodingAesKey, $corpId);
$errCode = $wxcpt->VerifyURL($sVerifyMsgSig, $sVerifyTimeStamp, $sVerifyNonce, $sVerifyEchoStr, $sEchoStr);
if ($errCode == 0) {
	
	echo $sEchoStr;
	
} else {
	print("ERR: " . $errCode . "\n\n");
}


?>


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 为了验证微信企业回调模式的URL,您可以按照以下步骤进行亲测。 首先,您需要在微信企业的后台设置回调模式的URL地址。这个URL地址需要指向您的服务器上的一个接收微信回调的脚本。 在服务器上,您可以使用PHP等编程语言编写一个处理微信回调的脚本。下面是一个PHP脚本的例子: ```php <?php $token = "your_token"; // 替换为您设置的Token值 $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $echostr = $_GET["echostr"]; $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr, SORT_STRING); $tmpStr = implode($tmpArr); $tmpStr = sha1($tmpStr); if($tmpStr == $signature){ echo $echostr; exit; } ?> ``` 在上面的示例代码中,您需要将`your_token`替换为您在微信企业后台设置的Token值。 然后,您可以将这个脚本上传到您的服务器上,并使用浏览器访问该脚本的URL,例如:`http://your_domain.com/callback.php?signature=xxxx&timestamp=xxxx&nonce=xxxx&echostr=xxxx`,其中`your_domain.com`替换为您的域名,`xxxx`替换为实际的参数值。 如果您在微信企业后台设置的URL验证通过,则浏览器会返回一个由微信服务器发送的`echostr`参数值。 通过以上操作,您可以完成对微信企业回调模式URL的验证。 ### 回答2: 亲测微信企业回调模式的URL验证代码如下: 1. 首先,获得微信企业后台提供的Token,用于加密验证。可以在配置页面或者开发页面找到该信息。 2. 创建一个URL接口用于接受微信企业发来的URL验证请求。接收到请求后,取出请求参数中的`echostr`值。 3. 将token、timestamp(请求时间戳)、nonce(随机数)和echostr按照字典序排序并拼接成一个字符串。 4. 将拼接后的字符串进行SHA-1加密。 5. 将加密后的字符串与微信企业发来的`msg_signature`进行比较,如果一致,则说明URL验证通过。 下面是一个示例代码(使用Python语言): ``` import hashlib import time from flask import Flask, request app = Flask(__name__) @app.route('/wechat', methods=['GET', 'POST']) def handle_wechat(): if request.method == 'GET': token = 'your_token' # 替换成微信企业后台提供的Token signature = request.args.get('signature') timestamp = request.args.get('timestamp') nonce = request.args.get('nonce') echostr = request.args.get('echostr') # 将token、timestamp、nonce按字典序排序并拼接 sorted_str = ''.join(sorted([token, timestamp, nonce])) # 对拼接后的字符串进行SHA-1加密 hashcode = hashlib.sha1(sorted_str.encode()).hexdigest() if hashcode == signature: return echostr else: return 'URL验证失败' if __name__ == '__main__': app.run() ``` 以上就是使用Python编写的微信企业回调模式的URL验证代码。当收到微信企业的URL验证请求时,会对请求参数进行验证,如果验证成功,则返回`echostr`作为响应内容。 ### 回答3: 亲测微信企业回调模式的URL验证代码如下: 在接收微信企业回调请求的URL页面中,需要编写一个方法来处理微信回调验证的逻辑。以下是一个简单的示例代码: ```php <?php $token = "your_token"; // 填写你在微信企业后台设置的Token // 验证URL的方法 function verifyURL($token) { // 接收微信服务器发送过来的参数 $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $echostr = $_GET["echostr"]; // 将Token、timestamp和nonce按照字典序排序 $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr, SORT_STRING); // 将排序后的三个参数拼接成一个字符串 $tmpStr = implode($tmpArr); // 对拼接后的字符串进行SHA1加密 $tmpStr = sha1($tmpStr); // 将加密后的字符串与接收到的signature进行比对 if($tmpStr == $signature) { // 验证通过,返回随机字符串用于校验 echo $echostr; } else { // 验证失败,返回错误信息 echo "URL验证失败"; } } // 调用验证URL的方法 verifyURL($token); ?> ``` 以上代码会先获取微信服务器发送过来的参数,然后对Token、timestamp和nonce进行排序,并拼接成一个字符串进行SHA1加密。最后将加密后的结果与接收到的signature进行比对,如果一致,则表示验证通过,返回随机字符串用于校验;如果不一致,则返回失败信息。 此代码可以在你编写的回调URL页面上直接使用,通过访问该URL来进行URL验证。请注意将代码中的"your_token"替换为你在微信企业后台设置的Token

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值