php代码
<?php
define("token", "weixin");
$wechatobj = new wechatcallbackapitest();
if (!isset($_get['echostr'])) {
$wechatobj->responsemsg();
}else{
$wechatobj->valid();
}
class wechatcallbackapitest
{
//验证签名
public function valid()
{
$echostr = $_get["echostr"];
$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);
if($tmpstr == $signature){
echo $echostr;
exit;
}
}
//响应消息
public function responsemsg()
{
$poststr = $globals["http_raw_post_data"];
if (!empty($poststr)){
$this->logger("r \r\n".$poststr);
$postobj = simplexml_load_string($poststr, 'simplexmlelement', libxml_nocdata);
$rx_type = trim($postobj->msgtype);
if (($postobj->msgtype == "event") && ($postobj->event == "subscribe" || $postobj->event == "unsubscribe")){
//过滤关注和取消关注事件
}else{
}
//消息类型分离
switch ($rx_type)
{
case "event":
$result = $this->receiveevent($postobj);
break;
case "text":
if (strstr($postobj->content, "第三方")){
$result = $this->relaypart3("http://www.fangbei.org/test.php".'?'.$_server['query_string'], $poststr);
}else{
$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 \r\n".$result);
echo $result;
}else {
echo "";
exit;
}
}
//接收事件消息
private function receiveevent($object)
{
$content = "";
switch ($object->event)
{
case "subscribe":
$content = "欢迎关注方倍工作室 ";
$content .= (!empty($object->eventkey))?("\n来自二维码场景 ".str_replace("qrscene_","",$object->eventkey)):"";
break;
case "unsubscribe":
$content = "取消关注";
break;
case "click":
switch ($object->eventkey)
{
case "company":
$content = array();
$content[] = array("title"=>"方倍工作室", "description"=>"", "picurl"=>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg", "url" =>"http://m.cnblogs.com/?u=txw1958");
break;
default:
$content = "点击菜单:".$object->eventkey;
break;
}
break;
case "view":
$content = "跳转链接 ".$object->eventkey;
break;
case "scan":
$content = "扫描场景 ".$object->eventkey;
break;
case "location":
$content = "上传位置:纬度 ".$object->latitude.";经度 ".$object->longitude;
break;
case "scancode_waitmsg":
if ($object->scancodeinfo->scantype == "qrcode"){
$content = "扫码带提示:类型 二维码 结果:".$object->scancodeinfo->scanresult;
}else if ($object->scancodeinfo->scantype == "barcode"){
$codeinfo = explode(",",strval($object->scancodeinfo->scanresult));
$codevalue = $codeinfo[1];
$content = "扫码带提示:类型 条形码 结果:".$codevalue;
}else{
$content = "扫码带提示:类型 ".$object->scancodeinfo->scantype." 结果:".$object->scancodeinfo->scanresult;
}
break;
case "scancode_push":
$content = "扫码推事件";
break;
case "pic_sysphoto":
$content = "系统拍照";
break;
case "pic_weixin":
$content = "相册发图:数量 ".$object->sendpicsinfo->count;
break;
case "pic_photo_or_album":
$content = "拍照或者相册:数量 ".$object->sendpicsinfo->count;
break;
case "location_select":
$content = "发送位置:标签 ".$object->sendlocationinfo->label;
break;
default:
$content = "receive a new event: ".$object->event;
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 receivetext($object)
{
$keyword = trim($object->content);
//多客服人工回复模式
if (strstr($keyword, "请问在吗") || strstr($keyword, "在线客服")){
$result = $this->transmitservice($object);
return $result;
}
//自动回复模式
if (strstr($keyword, "文本")){
$content = "这是个文本消息";
}else if (strstr($keyword, "表情")){
$content = "中国:".$this->bytes_to_emoji(0x1f1e8).$this->bytes_to_emoji(0x1f1f3)."\n仙人掌:".$this->bytes_to_emoji(0x1f335);
}else if (strstr($keyword, "单图文")){
$content = array();
$content[] = array("title"=>"单图文标题", "description"=>"单图文内容", "picurl"=>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg", "url" =>"http://m.cnblogs.com/?u=txw1958");
}else if (strstr($keyword, "图文") || strstr($keyword, "多图文")){
$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");
}else if (strstr($keyword, "音乐")){
$content = array();
$content = array("title"=>"最炫民族风", "description"=>"歌手:凤凰传奇", "musicurl"=>"http://121.199.4.61/music/zxmzf.mp3", "hqmusicurl"=>"http://121.199.4.61/music/zxmzf.mp3");
}else{
$content = date("y-m-d h:i:s",time())."\nopenid:".$object->fromusername."\n技术支持 方倍工作室";
}
if(is_array($content)){
if (isset($content[0])){
$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_y.";纬度为:".$object->location_x.";缩放级别为:".$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)
{
if (!isset($content) || empty($content)){
return "";
}
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[text]]></msgtype>
<content><![cdata[%s]]></content>
</xml>";
$result = sprintf($xmltpl, $object->fromusername, $object->tousername, time(), $content);
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']);
}
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[news]]></msgtype>
<articlecount>%s</articlecount>
<articles>
$item_str </articles>
</xml>";
$result = sprintf($xmltpl, $object->fromusername, $object->tousername, time(), count($newsarray));
return $result;
}
//回复音乐消息
private function transmitmusic($object, $musicarray)
{
if(!is_array($musicarray)){
return "";
}
$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']);
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[music]]></msgtype>
$item_str
</xml>";
$result = sprintf($xmltpl, $object->fromusername, $object->tousername, time());
return $result;
}
//回复图片消息
private function transmitimage($object, $imagearray)
{
$itemtpl = "<image>
<mediaid><![cdata[%s]]></mediaid>
</image>";
$item_str = sprintf($itemtpl, $imagearray['mediaid']);
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[image]]></msgtype>
$item_str
</xml>";
$result = sprintf($xmltpl, $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']);
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[voice]]></msgtype>
$item_str
</xml>";
$result = sprintf($xmltpl, $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']);
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[video]]></msgtype>
$item_str
</xml>";
$result = sprintf($xmltpl, $object->fromusername, $object->tousername, time());
return $result;
}
//回复多客服消息
private function transmitservice($object)
{
$xmltpl = "<xml>
<tousername><![cdata[%s]]></tousername>
<fromusername><![cdata[%s]]></fromusername>
<createtime>%s</createtime>
<msgtype><![cdata[transfer_customer_service]]></msgtype>
</xml>";
$result = sprintf($xmltpl, $object->fromusername, $object->tousername, time());
return $result;
}
//回复第三方接口消息
private function relaypart3($url, $rawdata)
{
$headers = array("content-type: text/xml; charset=utf-8");
$ch = curl_init();
curl_setopt($ch, curlopt_url, $url);
curl_setopt($ch, curlopt_returntransfer, 1);
curl_setopt($ch, curlopt_httpheader, $headers);
curl_setopt($ch, curlopt_post, 1);
curl_setopt($ch, curlopt_postfields, $rawdata);
$output = curl_exec($ch);
curl_close($ch);
return $output;
}
//字节转emoji表情
function bytes_to_emoji($cp)
{
if ($cp > 0x10000){ # 4 bytes
return chr(0xf0 | (($cp & 0x1c0000) >> 18)).chr(0x80 | (($cp & 0x3f000) >> 12)).chr(0x80 | (($cp & 0xfc0) >> 6)).chr(0x80 | ($cp & 0x3f));
}else if ($cp > 0x800){ # 3 bytes
return chr(0xe0 | (($cp & 0xf000) >> 12)).chr(0x80 | (($cp & 0xfc0) >> 6)).chr(0x80 | ($cp & 0x3f));
}else if ($cp > 0x80){ # 2 bytes
return chr(0xc0 | (($cp & 0x7c0) >> 6)).chr(0x80 | ($cp & 0x3f));
}else{ # 1 byte
return chr($cp);
}
}
//日志记录
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 = 1000000;
$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('y-m-d h:i:s')." ".$log_content."\r\n", file_append);
}
}
}
?>