直接上代碼,公衆号背景基本配置:
設定URL、token、EncodingAESKey,并退出啟用改配置,後上代碼
class TestController extends Controller
{
//公衆号背景的URL的接口
public function index()
{
//将timestamp,nonce,token按字典序排序
$timestamp = $_GET['timestamp'];
$nonce = $_GET['nonce'];
$token = 'weixin';
$signature = $_GET['signature'];
//将排序之後的三個參數拼接之後用sha1加密
$array = array($timestamp, $nonce, $token);
sort($array);
$tmpstr = implode('', $array);
$tmpstr = sha1($tmpstr);
//将加密後的字元串與sianature進行對比,判斷請求是否來自于微信
if ($tmpstr == $signature && $_GET['echostr']) {//第一次接入微信Api
echo $_GET['echostr'];
exit;
} else {
$this->responseMsg();
}
}
public function responseMsg()
{
//接收到的使用者消息格式<xml>
$postArr = $GLOBALS['HTTP_RAW_POST_DATA'];
// 接收到的消息格式
// <xml>
// <ToUserName><![CDATA[toUser]]></ToUserName>
// <FromUserName><![CDATA[FromUser]]></FromUserName>
// <CreateTime>123456789</CreateTime>
// <MsgType><![CDATA[event]]></MsgType>
// <Event><![CDATA[subscribe]]></Event>
// </xml>
//把接收到的xml格式資料包轉化為對象格式
$postObj = simplexml_load_string($postArr);
// 被動回複使用者消息格式
// <xml>
// <ToUserName><![CDATA[toUser]]></ToUserName>
// <FromUserName><![CDATA[fromUser]]></FromUserName>
// <CreateTime>12345678</CreateTime>
// <MsgType><![CDATA[text]]></MsgType>
// <Content><![CDATA[你好]]></Content>
// </xml>
if (strtolower($postObj->MsgType) == 'event') {//判斷是否為訂閱的事件推送
if (strtolower($postObj->Event) == 'subscribe') {//判斷是否為關注的事件推送
$toUser = $postObj->FromUserName;
$fromUser = $postObj->ToUserName;
$time = time();
$msgType = 'text';
$content = '你好:'.$postObj->FromUserName.'!歡迎關注我們的微信公衆号';
$template = "<xml>
<ToUserName><![CDATA[%s]]></ToUserNames>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
</xml>";
$info = sprintf($template, $toUser, $fromUser, $time, $msgType, $content);
echo $info;
}
}
}