<?php namespace app\api\controller; use app\common\controller\Api; use app\common\library\Tool; use think\Request; /** * 无须token验证接口 */ class Wxreply extends Api { // 无需登录的接口,*表示全部 protected $noNeedLogin = '*'; public function _initialize() { parent::_initialize(); } //微信公众号验证checkToken public function checkToken() { $data=Request::instance()->get(); //var_dump($data);exit; $echostr = $data['echostr']; $signature = $data['signature']; $timestamp = $data['timestamp']; $nonce = $data['nonce']; // 计算微信签名 $token ="687687";//自定义token //将参数组成一维数组 $signeSeed = [$token, $timestamp, $nonce]; //对参数字典序排序 sort($signeSeed, SORT_STRING); //拼接成字符串 $signeStr = implode($signeSeed); //加密字符串成签名 $signeHash = sha1($signeStr); // self::getcode(); if( $signeHash == $signature && $echostr){ echo $echostr; exit; }else{ $this->responseMsg(); } } //返回信息 public function responseMsg(){ $postStr = file_get_contents("php://input");//访问请求的原始数据的只读流 if (!empty($postStr)){ $this->logger("R ".$postStr); //考虑到了安全问题。 libxml_disable_entity_loader(true); //得到了数据之后,然后我们就是要解析微信服务器发送过来的xml数据包了 $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $RX_TYPE = trim($postObj->MsgType); $fromruseropenid=trim($this->getUserInfo($postObj->FromUserName)); //关注之后利用二次opendi,获取用户信息 $userinfostr=json_decode($fromruseropenid,true)["nickname"]; switch ($RX_TYPE) { case "event": $result = $this->receiveEvent($postObj,$userinfostr); break; case "text": $result = $this->receiveText($postObj); break; case "image": $result = $this->receiveImage($postObj); break; case "location": $result = $this->receiveLocation($postObj); break; case "voice": $result = $this->receiveVoice($postObj); break; case "video": $result = $this->receiveVideo($postObj); break; case "link": $result = $this->receiveLink($postObj); break; default: $result = "unknown msg type: ".$RX_TYPE; break; } $this->logger("T ".$result); echo $result; }else { echo ""; exit; } } //接收事件消息 private function receiveEvent($object,$userinfostr) { $content = ""; switch ($object->Event) { case "subscribe": $content = "人间风日不到处,天上玉堂森宝书。"."\n你好啊,网络的旅行者:".$userinfostr.",放松一下疲惫的心灵,这里是xx教育,享受国家政策扶持,学技能,拿证书!"; // $content .= (!empty($object->EventKey))?("\n来自二维码场景 ".str_replace("qrscene_","",$object->EventKey)):""; break; case "unsubscribe": $content = "取消关注"; break; case "SCAN": $content = "扫描场景 ".$object->EventKey; break; case "CLICK": switch ($object->EventKey) { case "COMPANY": $content = "xx教育提供互联网相关产品与服务。"; break; default: $content = "点击菜单:".$object->EventKey; break; } break; case "LOCATION": $content = "上传位置:纬度 ".$object->Latitude.";经度 ".$object->Longitude; break; case "VIEW": $content = "跳转链接 ".$object->EventKey; break; default: $content = "receive a new event: ".$object->Event; break; } $result = $this->transmitText($object, $content); return $result; } //接收文本消息 private function receiveText($object) { switch ($object->Content) { case "文本": $content = "这是个文本消息"; break; case "你是?": $content = "一个不愿透露名字的机器人,略略略"; break; case "你好": $content = "我们专注教育培训行业17年,随着互联网科技的兴起,我们打造了全新的培训模式:互联网+职业技能+公益教育。搭建共享职业教育平台、结合政策技能免费培训、实现信用免费学习。"; break; case "图文": case "单图文": $content = array(); $content[] = array("Title"=>"xx教育小程序,扫码体验", "Description"=>"官方网址点击查看", "PicUrl"=>"", "Url" =>"https://baidu.cn/"); break; case "多图文": $content = array(); $content[] = array("Title"=>"多图文1标题", "Description"=>"", "PicUrl"=>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958"); $content[] = array("Title"=>"多图文2标题", "Description"=>"", "PicUrl"=>"http://d.hiphotos.bdimg.com/wisegame/pic/item/f3529822720e0cf3ac9f1ada0846f21fbe09aaa3.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958"); $content[] = array("Title"=>"多图文3标题", "Description"=>"", "PicUrl"=>"http://g.hiphotos.bdimg.com/wisegame/pic/item/18cb0a46f21fbe090d338acc6a600c338644adfd.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958"); break; case "音乐": $content = array("Title"=>"大鱼", "Description"=>"歌手:周深", "MusicUrl"=>"http://fs.w.kugou.com/201806221135/3f0e5973d2cee2c083fd1d0a129921d3/G063/M08/05/11/H5QEAFc-bc6AfD3uAEycKVKAkaw783.mp3", "HQMusicUrl"=>"http://fs.w.kugou.com/201806221135/3f0e5973d2cee2c083fd1d0a129921d3/G063/M08/05/11/H5QEAFc-bc6AfD3uAEycKVKAkaw783.mp3"); break; default: $content = "技术支持 xx教育"; break; } if(is_array($content)){ if (isset($content[0]['PicUrl'])){ $result = $this->transmitNews($object, $content); }else if (isset($content['MusicUrl'])){ $result = $this->transmitMusic($object, $content); } }else{ $result = $this->transmitText($object, $content); } return $result; } //接收图片消息 private function receiveImage($object) { $content = array("MediaId"=>$object->MediaId); $result = $this->transmitImage($object, $content); return $result; } //接收位置消息 private function receiveLocation($object) { $content = "你发送的是位置,纬度为:".$object->Location_X.";经度为:".$object->Location_Y.";缩放级别为:".$object->Scale.";位置为:".$object->Label; $result = $this->transmitText($object, $content); return $result; } //接收语音消息 private function receiveVoice($object) { if (isset($object->Recognition) && !empty($object->Recognition)){ $content = "你刚才说的是:".$object->Recognition; $result = $this->transmitText($object, $content); }else{ $content = array("MediaId"=>$object->MediaId); $result = $this->transmitVoice($object, $content); } return $result; } //接收视频消息 private function receiveVideo($object) { $content = array("MediaId"=>$object->MediaId, "ThumbMediaId"=>$object->ThumbMediaId, "Title"=>"", "Description"=>""); $result = $this->transmitVideo($object, $content); return $result; } //接收链接消息 private function receiveLink($object) { $content = "你发送的是链接,标题为:".$object->Title.";内容为:".$object->Description.";链接地址为:".$object->Url; $result = $this->transmitText($object, $content); return $result; } //回复文本消息 private function transmitText($object, $content) { $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[text]]></MsgType> <Content><![CDATA[%s]]></Content> </xml>"; $result = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time(), $content); return $result; } //回复图片消息 private function transmitImage($object, $imageArray) { $itemTpl = "<Image> <MediaId><![CDATA[%s]]></MediaId> </Image>"; $item_str = sprintf($itemTpl, $imageArray['MediaId']); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[image]]></MsgType> $item_str </xml>"; $result = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time()); return $result; } //回复语音消息 private function transmitVoice($object, $voiceArray) { $itemTpl = "<Voice> <MediaId><![CDATA[%s]]></MediaId> </Voice>"; $item_str = sprintf($itemTpl, $voiceArray['MediaId']); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[voice]]></MsgType> $item_str </xml>"; $result = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time()); return $result; } //回复视频消息 private function transmitVideo($object, $videoArray) { $itemTpl = "<Video> <MediaId><![CDATA[%s]]></MediaId> <ThumbMediaId><![CDATA[%s]]></ThumbMediaId> <Title><![CDATA[%s]]></Title> <Description><![CDATA[%s]]></Description> </Video>"; $item_str = sprintf($itemTpl, $videoArray['MediaId'], $videoArray['ThumbMediaId'], $videoArray['Title'], $videoArray['Description']); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[video]]></MsgType> $item_str </xml>"; $result = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time()); return $result; } //回复图文消息 private function transmitNews($object, $newsArray) { if(!is_array($newsArray)){ return; } $itemTpl = " <item> <Title><![CDATA[%s]]></Title> <Description><![CDATA[%s]]></Description> <PicUrl><![CDATA[%s]]></PicUrl> <Url><![CDATA[%s]]></Url> </item> "; $item_str = ""; foreach ($newsArray 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> </xml>"; $result = sprintf($newsTpl, $object->FromUserName, $object->ToUserName, time(), count($newsArray)); return $result; } //回复音乐消息 private function transmitMusic($object, $musicArray) { $itemTpl = "<Music> <Title><![CDATA[%s]]></Title> <Description><![CDATA[%s]]></Description> <MusicUrl><![CDATA[%s]]></MusicUrl> <HQMusicUrl><![CDATA[%s]]></HQMusicUrl> </Music>"; $item_str = sprintf($itemTpl, $musicArray['Title'], $musicArray['Description'], $musicArray['MusicUrl'], $musicArray['HQMusicUrl']); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[music]]></MsgType> $item_str </xml>"; $result = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time()); return $result; } //日志记录 private function logger($log_content) { if(isset($_SERVER['HTTP_APPNAME'])){ //SAE sae_set_display_errors(false); sae_debug($log_content); sae_set_display_errors(true); }else if($_SERVER['REMOTE_ADDR'] != "127.0.0.1"){ //LOCAL $max_size = 10000; $log_filename = "log.xml"; if(file_exists($log_filename) and (abs(filesize($log_filename)) > $max_size)){unlink($log_filename);} file_put_contents($log_filename, date('H:i:s')." ".$log_content."\r\n", FILE_APPEND); } } //--------------------------------------------------------------公众号关注回复及关键字回复end----------------------------------------------------------------------------------------- //公众平台 private $WX_APPID="wx9b1ec4fegrgf1fawf"; private $WX_SECRET="8e3e63698ddac81947f52b0a7baaaafd"; //创建菜单 public function creatMenu() { // var_dump(self::getAccessToken());exit; //组装请求的url地址 $url = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".self::getAccessToken(); $data = array( // button下的每一个元素 "button"=>array( //第一个一级菜单 // array('type'=>'view',"name"=>"百度",'url'=>"https://www.baidu.com"), array('type'=>'miniprogram','name'=>'夏令营','url'=>'http://mp.weixin.qq.com','appid'=>'wxb3dddde5704f9c5','pagepath'=>'pages/baoming/baoming'), // array('type'=>'miniprogram','name'=>'教育','url'=>'http://mp.weixin.qq.com','appid'=>'wxbddd1d1ce5704f9c5','pagepath'=>'pages/index/index'), ) ); // 将数据转换为json格式 $data = json_encode($data,JSON_UNESCAPED_UNICODE); $curl= new Tool(); $result = $curl->http_curl($url,$data,'post'); dump($result); } //获取自定义菜单 public function getMenu() { $url = "https://api.weixin.qq.com/cgi-bin/menu/get?access_token=".self::getAccessToken(); $curl= new Tool(); $res =$curl->http_curl($url); var_dump($res); } // 删除自定义菜单 public function delMenu() { $url = 'https://api.weixin.qq.com/cgi-bin/menu/delete?access_token='.self::getAccessToken(); $curl= new Tool(); $res =$curl->http_curl($url); dump($res); } //关注之后返回用户的信息 public function getUserInfo($openid){ //获取token $toen=$this->getAccessToken(); $url="https://api.weixin.qq.com/cgi-bin/user/info?access_token=$toen&openid=$openid&lang=zh_CN"; $data=file_get_contents($url); $user=json_decode($data,true); $unionid=$user["openid"]; $urll="https://api.weixin.qq.com/cgi-bin/user/info?access_token=$toen&openid=$unionid&lang=zh_CN"; //获取用户信息 $userifnfo=file_get_contents($urll); return $userifnfo; } /*获取AccessToken (获取之前先确认ip地址在白名单内!!!) */ public function getAccessToken() { // Session::start(); // $data = Session::get('gzhAccessToken'); // if ($data['expire_time'] < time() || empty($data)) { // 如果是企业号用以下URL获取access_token // $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret"; $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->WX_APPID&secret=$this->WX_SECRET"; $curl= new Tool(); $res = $curl->http_curl($url); $access_token = $res['access_token']; /*if ($access_token) { $data['expire_time'] = time() + 7000; $data['access_token'] = $access_token; Session::set('gzhAccessToken',$data); } } else { $access_token = $data['access_token']; }*/ return $access_token; } }
public function http_curl($url,$data =array(),$method ="get",$returnType ="json") { //1.开启会话 $ch = curl_init(); //2.设置参数 curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE); curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false); if($method!="get"){ curl_setopt($ch,CURLOPT_POST,TRUE); curl_setopt($ch,CURLOPT_POSTFIELDS,$data); } curl_setopt($ch,CURLOPT_URL,$url); //执行会话 $json = curl_exec($ch); curl_close($ch); if($returnType == "json"){ return json_decode($json,true); } return $json; }