您的位置:首页 > 移动开发 > 微信开发

微信服务号提示"该公众号暂时无法提供服务请稍后再试"原因以及解决方法

2016-11-12 21:30 651 查看
网上看到太多的“复制哥”了,我自己亲身经历过的,给大家说话所吧!

【一般主要原因有两个】:1-你的代码本身就有问题(这个太常见,我这里就不赘述了,2-就是我下面说的情况,如果你已经确保你的代码没问题,那就看下面的,很有可能就是下面的情况造成的)

第一步:先确定配置是否正确



第二步:如果配置都正确了,继续看下面

下面这段代码,摘自官方案例文档的,拿到后Token后面的值要换位自己编号的那个字符串,下面的代码我备注的有

<?php
/**
* wechat php test
*/

//define your token
define("TOKEN", "填写你自己编好的那个Token");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid();

class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET["echostr"];

//valid signature , option
if($this->checkSignature()){
echo $echoStr;
exit;
}
}

public function responseMsg()
{
//get post data, May be due to the different environments
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

//extract post data
if (!empty($postStr)){
/* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection,
the best way is to check the validity of xml by yourself */
libxml_disable_entity_loader(true);
$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
$fromUsername = $postObj->FromUserName;
$toUsername = $postObj->ToUserName;
$keyword = trim($postObj->Content);
$time = time();
$textTpl = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>0</FuncFlag>
</xml>";
if(!empty( $keyword ))
{
$msgType = "text";
$contentStr = "Welcome to wechat world!";
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
echo $resultStr;
}else{
echo "Input something...";
}

}else {
echo "";
exit;
}
}

private function checkSignature()
{
// you must define TOKEN by yourself
if (!defined("TOKEN")) {
throw new Exception('TOKEN is not defined!');
}

$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];

$token = TOKEN;
$tmpArr = array($token, $timestamp, $nonce);
// use SORT_STRING rule
sort($tmpArr, SORT_STRING);
$tmpStr = implode( $tmpArr );
$tmpStr = sha1( $tmpStr );

if( $tmpStr == $signature ){
return true;
}else{
return false;
}
}
}

?>


第三部:上面的代码写好之后,这个代码一定要确保你填写的那个URL能访问到这个脚本,且能执行到这段代码,URL前面我们已经配好了,如下图,确保URL和自己编的Token (你这里填的要和代码里面的保持相同的字符串) 都准备好后,点击“提交按钮”如下图



第四部:也是很多人往往忽略,造成报错的原因,一定要把下面的验证代码注释掉,因为上面我们点击的“提交”按钮已经校验过了,所以这次不用再提交了,直接注释掉,同时再加一行代码。具体如下图所示



好了!大公告成!其实不是微信的什么BUG,主要都是自己粗心造成的!微信这么大的一个团队开发的东西,中国多少人在用,肯定已经很完善了,遇到问题先找你的问题,不要动不动就说别人怎么怎么的,其实是你自己不行!

感谢大家阅读!希望能帮到你!如果有不足之处请回复或者给我留言!纯属原创!转载本文章请说明来源,尊重原创!谢谢!~
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐