用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

微信开发笔记之接收消息,自动判断回复相应消息

时间:2015-01-23  来源:西部数据  作者:西部数据

微信的api现在己经强大到可以随意调用我们网站或指定数据库的内容进行自能回复现推送消息了,现在我来给大家介绍一个我微信开的笔记.

山猫的博客,发送1,2,3,7测试相应的消息,菜单模式需要升级为服务号,或者订阅人数超过500以上.

1.用户发送的消息都是通过你提交的开发者URL来接收,这里订阅号就可以搞定,发送过来的都是xml格式数据,需要解析,代码如下:

  1. $data = $GLOBALS["HTTP_RAW_POST_DATA"]; 
  2. if (!emptyempty($data)) {//接收消息并处理 
  3. $xml = (array)simplexml_load_string($data, ‘SimpleXMLElement’, LIBXML_NOCDATA); 
  4. return $xml

回复也是需要返回XML的数据格式.

2.主动发送给用户消息,查询用户信息,创建自定义菜单(现在订阅号也可以用),以及一些高级功能,都是需要获取appid 和 AppSecret 以便得到 access_token.

access_token 这东西,除接收信息,每个接口都要用到,access_token 的时间为 7200毫秒过期需要重新获取.

更多请参考:http://mp.weixin.qq.com/wiki/index.php?title=%E9%A6%96%E9%A1%B5.

目前我已经实现了,接收消息,自动判断回复相应消息新闻,创建自定义菜单,点击自定义菜单后执行相应操作,用户列表之类,感觉目前开发模式和订阅模式没什么区别.

这里有一个测试回复的测试例子,代码如下:

  1. <?php 
  2. /** 
  3.   * wechat php test 
  4.   */ 
  5.  
  6. //define your token 
  7. define("TOKEN""你的申请上的token"); 
  8. $wechatObj = new wechatCallbackapiTest(); 
  9. $wechatObj->valid(); 
  10.  
  11. class wechatCallbackapiTest 
  12.  public function valid() 
  13.     { 
  14.         $echoStr = $_GET["echostr"]; 
  15.  
  16.         //valid signature , option 
  17.         if($this->checkSignature()){ 
  18.          $this->responseMsg(); 
  19.          exit
  20.         } 
  21.     } 
  22.  
  23.     public function responseMsg() 
  24.     { 
  25.   //get post data, May be due to the different environments 
  26.   $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; 
  27.  
  28.        //extract post data 
  29.   if (!emptyempty($postStr)){ 
  30.                  
  31.                $postObj = simplexml_load_string($postStr'SimpleXMLElement', LIBXML_NOCDATA); 
  32.                 $fromUsername = $postObj->FromUserName; 
  33.                 $toUsername = $postObj->ToUserName; 
  34.                 $keyword = trim($postObj->Content); 
  35.                 $time = time(); 
  36.     $msgType = "text"
  37.                 $textTpl = "<xml> 
  38.        <ToUserName><![CDATA[%s]]></ToUserName> 
  39.        <FromUserName><![CDATA[%s]]></FromUserName> 
  40.        <CreateTime>%s</CreateTime> 
  41.        <MsgType><![CDATA[%s]]></MsgType> 
  42.        <Content><![CDATA[%s]]></Content> 
  43.        <FuncFlag>0</FuncFlag> 
  44.        </xml>";              
  45.     if(!emptyempty$keyword )) 
  46.                 { 
  47.                  
  48.                  $contentStr = $this->keyrep($keyword); 
  49.      if(  emptyempty($contentStr) ) 
  50.      { 
  51.       $contentStr ="你是故意的吧,没文化真可怕";//你是故意的吧,没文化真可怕; 
  52.      } 
  53.      //$contentStr = @iconv('UTF-8','gb2312',$keyword); 
  54.                  $resultStr = sprintf($textTpl$fromUsername$toUsername$time$msgType$contentStr); 
  55.                  echo $resultStr
  56.       
  57.                 }else
  58.                  $contentStr = '没文化真可怕,居然不会打字!';//$this->keyrep($keyword); 
  59.                  //$contentStr = @iconv('UTF-8','gb2312',$keyword); 
  60.      $resultStr = sprintf($textTpl$fromUsername$toUsername$time$msgType$contentStr); 
  61.                  echo $resultStr
  62.                 } 
  63.  
  64.         }else { 
  65.          echo ""
  66.          exit
  67.         } 
  68.     } 
  69.    
  70.  private function checkSignature() 
  71.  { 
  72.         $signature = $_GET["signature"]; 
  73.         $timestamp = $_GET["timestamp"]; 
  74.         $nonce = $_GET["nonce"];  
  75.            
  76.   $token = TOKEN; 
  77.   $tmpArr = array($token$timestamp$nonce); 
  78.   sort($tmpArr); 
  79.   $tmpStr = implode( $tmpArr ); 
  80.   $tmpStr = sha1( $tmpStr ); 
  81.    
  82.   if$tmpStr == $signature ){ 
  83.    return true; 
  84.   }else
  85.    return false; 
  86.   } 
  87.  } 
  88.  
  89.  function keyrep($key
  90.  { 
  91.   //return $key; 
  92.   if$key=='嗨' || $key=='在吗' || $key=='你好' ){ 
  93.     $mt = mt_rand(1,17); 
  94.     $array = array(1=>'自杀中,稍后再说...',2=>'有事找我请大叫!',3=>'我正在裸奔,已奔出服务区',4=>'我现在位置:WC; 姿势:下蹲; 脸部:抽搐; 状态:用力中。。。。',5=>'去吃饭了,如果你是帅哥,请一会联系我,如果你是美女...............就算你是美女,我也要先吃饱肚子啊',6=>'  
  95. 洗澡中~谢绝旁观!!^_^0',7=>'有熊出?],我去诱捕,尽快回来。',8=>'你好,我是500,请问你是250吗?',9=>'喂!乱码啊,再发',10=>' 
  96. 不是我不理你,只是时间难以抗拒!',11=>'你刚才说什么,我没看清楚,请再说一遍!',12=>'发多几次啊~~~发多几次我就回你。',13=>'此人已死,有事烧纸!',14=>'乖,不急哦…',15=>'你好.我去杀几个人,很快回来.',16=>'本人已成仙?有事请发烟?佛说有烟没火成不了正果?有火没烟成不了仙。',17=>' 
  97. 你要和我说话?你真的要和我说话?你确定自己想说吗?你一定非说不可吗?那你说吧,这是自动回复,反正我看不见其实我在~就是不回你拿我怎么着?' 
  98. ); 
  99.    return $array[$mt]; 
  100.    
  101.   } 
  102.    
  103.   if$key=='靠' || $key=='啊' || $key=='阿' ) 
  104.   { 
  105.     $mt = mt_rand(1,19); 
  106.     $array = array(1=>'人之初?性本善?玩心眼?都滚蛋。',2=>'今后的路?我希望你能自己好好走下去?而我  坐车',3=>'笑话是什么?就是我现在对你说的话。',4=>'人人都说我丑?其实我只是美得不明显。',5=>'A;猪是怎么死的?B;你还没死我怎么知道',6=>'  
  107. 奥巴马已经干掉和他同姓的两个人?奥特曼你要小心了。 ',7=>'有的人活着?他已经死了?有的人活着?他早该死了。',8=>'"妹妹你坐船头?哥哥我岸上走"据说很傻逼的人看到都是唱出来的。',9=>'我这辈子只有两件事不会?这也不会?那也不会。',10=>' 
  108. 过了这个村?没了这个店?那是因为有分店。',11=>'我以为你只是个球?没想到?你真是个球。',12=>'你终于来啦,我找你N年了,去火星干什么了?我现在去冥王星,回头跟你说个事,别走开啊',13=>'你有权保持沉默,你所说的一切都将被作为存盘记录。你可以请代理服务器,如果请不起网络会为你分配一个。',14=>'本人正在被国际刑警组织全球范围内通缉,如果您有此人的消息,请拨打当地报警电话',15=>'洗澡中~谢绝旁观!!^_^0',16=>'嘀,这里是移动秘书, 美眉请再发一次,我就与你联系;姐姐请再发两次,我就与你联系;哥哥、弟弟就不要再发了,因为发了也不和你联系!',17=>' 
  109. 其实我在~就是不回你拿我怎么着?',18=>'你刚才说什么,我没看清楚,请再说一遍!',19=>'乖,不急。。。'); 
  110.    return $array[$mt]; 
  111.   } 
  112.    
  113.   if$key =='请问' ) 
  114.   { 
  115.    $mt = mt_rand(1,5); 
  116.    $array = array(1=>'"我脸油吗"反光??反正我不清楚',2=>'走,我请你吃饭',3=>'此人已死,有事烧纸!',4=>'喂!什么啊!乱码啊,再发',5=>'笑话是什么??就是我现在对你说的话。'); 
  117.    return $array[$mt]; 
  118.   }//开源代码phpfensi.com 
  119.    
  120.   return ""
  121.    
  122.  } 
  123.  
  124.  function keylist() 
  125.  { 
  126.   $array  = array(1=>'嗨',2=>'你好',3=>'靠',4=>'在吗',5=>'请问'); 
  127.  } 
  128.  
  129. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门