微信公众号开发验证服务器Token失败
2016-08-08 17:41
477 查看
//////////////2016/08/08///////////////////
///////////////by xbw/////////////////////////
///////////////////////////////////////////////////
微信公众号开发验证服务器Token失败
最后终于找到解决方法了,楼主结贴了但是没有留下解决方法,我现在给出我的问题和解决方法,希望对大家有用:
我也遇到这个问题,我的情况是这样的,用的框架,echo $echoStr也是对的,但是就是提升token验证失败,没有bom头,编码也是正确的,响应时间也是对的,最后在echo $echoStr前面加一句ob_clean();就好了,回答出来希望对大家有用。
<?php
/**
* wechat php test
*/
//define your token
define("TOKEN", "xbw12138");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid();
class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET["echostr"];
//valid signature , option
if($this->checkSignature()){
ob_clean();
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);
ob_clean();
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;
}
}
}
?>
///////////////by xbw/////////////////////////
///////////////////////////////////////////////////
微信公众号开发验证服务器Token失败
最后终于找到解决方法了,楼主结贴了但是没有留下解决方法,我现在给出我的问题和解决方法,希望对大家有用:
我也遇到这个问题,我的情况是这样的,用的框架,echo $echoStr也是对的,但是就是提升token验证失败,没有bom头,编码也是正确的,响应时间也是对的,最后在echo $echoStr前面加一句ob_clean();就好了,回答出来希望对大家有用。
<?php
/**
* wechat php test
*/
//define your token
define("TOKEN", "xbw12138");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid();
class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET["echostr"];
//valid signature , option
if($this->checkSignature()){
ob_clean();
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);
ob_clean();
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;
}
}
}
?>
相关文章推荐
- 阿里云服务器开发微信公众号,配置的时候总是TOKEN验证失败
- 关于ThinkPHP框架开发微信公众号在微信后台配置服务器URL提示Token验证失败的解决方案
- 阿里云服务器微信接口开发TOKEN验证失败
- [置顶] 关于微信公众号开发的Token验证失败该如何解决?
- PHP微信开发新浪sea服务器提示token验证失败
- 微信公众号开发 配置服务器URL,验证Token
- 微信公众号:搭建新浪SAE服务器,遇到token验证失败的问题
- 使用新浪SAE开发微信公众号 验证Token却一直失败
- java 微信开发token验证失败的一种情况
- 微信公众平台开发者中心服务器配置Token验证失败问题
- [ZZ]SAE微信公众号PHP SDK, token一直验证失败
- 百度云引擎BAE连接微信开发平台TOKEN验证失败
- java微信公众号开发 - 微信服务器的接入和验证
- 微信公众平台开发者中心服务器配置Token验证失败问题
- php版微信开发Token验证失败或请求URL超时问题的解决方法
- 微信公众平台开发——token验证失败
- 微信公众平台开发Token验证失败(有时URL超时)--解决方案
- 微信公众号提交开发者提示token验证失败
- 微信开发 新浪SAE开发平台 验证Token 一直失败