加密/校验流程如下:
1. 将token、timestamp、nonce三个参数进行字典序排序
2. 将三个参数字符串拼接成一个字符串进行sha1加密
3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
<?php 

class Weixin extends My_Controller
{
public function __construct()
{
parent::__construct();
define('TOKEN','123456'); //定义常量
} public function test()
{
header("Content-type:text/html;charset=utf-8");
if (!isset($_GET['echostr']))
{
$this->responseMsg();
}
else
{
$this->valid();
}
} public function valid()
{
$echostr = $_GET["echostr"];
if($this->check()){
header("Content-type:text");
ob_clean();
echo $echostr; //开发者模式接收到$echostr,再输出回去
exit;
}
} public function check()
{
$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"]; $token = TOKEN;
$tmpArr = array($token, $timestamp, $nonce);
sort($tmpArr, SORT_STRING); //排序
$tmpStr = implode( $tmpArr ); //数组变成字符串
$tmpStr = sha1( $tmpStr ); //sha1加密 if( $tmpStr == $signature ){
return true;
}else{
return false;
}
} public function responseMsg()
{
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];
if (!empty($postStr)){
$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
$RX_TYPE = trim($postObj->MsgType); switch ($RX_TYPE)
{
case "text":
$resultStr = $this->receiveText($postObj);
break;
case "event":
$resultStr = $this->receiveEvent($postObj);
break;
default:
$resultStr = "";
break;
}
echo $resultStr;
}else {
echo "";
exit;
}
} private function receiveText($object)
{
$funcFlag = 0;
$contentStr = "你发送的内容为:".$object->Content;
$resultStr = $this->transmitText($object, $contentStr, $funcFlag);
return $resultStr;
} private function receiveEvent($object)
{
$contentStr = "";
switch ($object->Event)
{
case "subscribe":
$contentStr = "欢迎关注逍游";
case "unsubscribe":
break;
case "CLICK":
switch ($object->EventKey)
{
case "company":
$contentStr[] = array("Title" =>"公司简介",
"Description" =>"逍游提供好玩的手游",
"PicUrl" =>"http://gameapi.xiaoyou-game.com/images/example.jpg",
"Url" =>"http://xiaoyou-game.com");
break;
case "game":
$contentStr[] = array("Title" =>"星座召唤",
"Description" =>"八十八星座来袭,你是什么座?",
"PicUrl" =>"http://gameapi.xiaoyou-game.com/images/example.jpg",
"Url" =>"http://xzzh.xiaoyou-game.com");
break;
case "dhm":
$contentStr[] = array("Title" =>"礼包兑换码",
"Description" =>"快点击领取游戏礼包兑换码吧~",
"PicUrl" =>"http://gameapi.xiaoyou-game.com/images/example.jpg",
"Url" =>"http://xzzh.xiaoyou-game.com/web/list/lbdhm.shtml");
break;
default:
$contentStr[] = array("Title" =>"默认菜单回复",
"Description" =>"您正在使用的是自定义菜单测试接口",
"PicUrl" =>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg",
"Url" =>"weixin://addfriend/pondbaystudio");
break;
}
break;
default:
break; }
if (is_array($contentStr)){
$resultStr = $this->transmitNews($object, $contentStr);
}else{
$resultStr = $this->transmitText($object, $contentStr);
}
return $resultStr;
} private function transmitText($object, $content, $funcFlag = 0)
{
$textTpl = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>%d</FuncFlag>
</xml>";
$resultStr = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time(), $content, $funcFlag);
return $resultStr;
} private function transmitNews($object, $arr_item, $funcFlag = 0)
{
//首条标题28字,其他标题39字
if(!is_array($arr_item))
return; $itemTpl = " <item>
<Title><![CDATA[%s]]></Title>
<Description><![CDATA[%s]]></Description>
<PicUrl><![CDATA[%s]]></PicUrl>
<Url><![CDATA[%s]]></Url>
</item>
"; $item_str = "";
foreach ($arr_item as $item)
$item_str .= sprintf($itemTpl, $item['Title'], $item['Description'], $item['PicUrl'], $item['Url']); $newsTpl = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[news]]></MsgType>
<Content><![CDATA[]]></Content>
<ArticleCount>%s</ArticleCount>
<Articles>
$item_str</Articles>
<FuncFlag>%s</FuncFlag>
</xml>"; $resultStr = sprintf($newsTpl, $object->FromUserName, $object->ToUserName, time(), count($arr_item), $funcFlag);
return $resultStr;
} }

最新文章

  1. 一个可拖拽的DIV框框
  2. (转)awk实例练习(二)
  3. UDP/TCP
  4. C#中数组Array、ArrayList、泛型List&lt;T&gt;的比较
  5. Winform TreeList递归绑定树节点
  6. “display:block-inline形式的Span或Div中添加文字后,导致Span或Div排版掉落、错位”的原因及解决方法
  7. Java对象的序列化和反序列化实践
  8. C++中的冒泡排序,选择排序,插入排序
  9. MS SQLService中的*= 及 =*
  10. Android中使用HttpGet和HttpPost访问HTTP资源
  11. ZOJ 3529 A Game Between Alice and Bob(博弈论-sg函数)
  12. jquery的img的动态title换行
  13. View处理常用方法封装
  14. 字符设备驱动(六)按键poll机制
  15. 我们为什么要在Android中使用RxJava
  16. 递归函数获得n个不重复的随机数
  17. Linux重启服务器步骤
  18. 洛谷 P3916 【图的遍历】反向加边+dfs
  19. iOS开发-UIRefreshControl下拉刷新
  20. Oracle12c中数据删除(delete)新特性之数据库内归档功能

热门文章

  1. finally块中的代码一定会执行吗?
  2. 知名黑客组织Anonymous(匿名者)的装备库
  3. MATLAB 生成数据保存至文件
  4. Oracle知识整理
  5. [工作技能]SVN
  6. 微软MVP社区夏日巡讲北京站 7月13日星期六 微软北京望京Office
  7. centos6.5 64位系统安装 tengine
  8. CentOS查看软件源提供的软件版本命令
  9. ext afteredit
  10. iOS --- 通过openURL实现APP之间跳转并传递数据