<?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;
}