1:开发模式和编辑模式请求流程的区别
编辑模式
开发模式
2:函数学习
函数:simplexml_load_string()
作用:将xml字符串载入到对象中
函数:sprintf()
作用:将字符串中的百分号替换成变量
3:架设内网穿透服务
网址:
架设内网穿透服务:[https://natapp.cn/article/natapp_newbie]
配置文件下载:[https://natapp.cn/article/config_ini]
1:本地配置微信虚拟主机(注:必须是第一个虚拟主机)。
2:按文档架设内网穿透服务。
3:配置文件中复制来的代码里修改authtoken就行。
4:启用服务并访问测试即可。
4:切换开发模式
步骤一:(填写服务器配置 参考接口文档接入指南):切换到微信公众平台,开启开发者模式。
步骤二:在站点目录中创建微信接口文件,该文件内容复制微信SDK内容
步骤三:重新切换到微信公众平台,提交验证并启用
步骤四:打开公众号聊天窗口,输入内容测试。
SDK下载地址:[http://mp.weixin.qq.com/mpres/htmledition/res/wx_sample.20140819.zip]
注:在填写服务器配置的时候的token必须和接口文件中的token一致
5:微信的6大接收接口
判断发送的数据类型(主要通过MsgType来进行判断)代码:
//判断微信服务器推送的数据类型
switch ($postObj->MsgType) {
case 'text':
# code...
$content = '文本消息';
break;
case 'image':
# code...
$content = '图片消息';
break;
case 'voice':
# code...
$content = '语音消息';
break;
case 'video':
$content = '视频消息';
# code...
break;
case 'location':
$content = '位置消息';
# code...
break;
case 'link':
$content = '链接消息';
# code...
break;
default:
# code...
$content = '你有瑕疵';
break;
}
6:组装响应的XML格式
//组装响应的xml格式
$textTpl = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>0</FuncFlag>
</xml>";
$msgType = "text";
//将变量数据替换字符串中的%s
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $content)
//响应xml给腾讯服务器
echo $resultStr;
7:微信订阅回复接口开发(点击订阅后自动回复消息)
参考:开发文档--消息管理--接收事件推送--关注和取消关注事件
实现:只需要在上面的判断数据类型代码中增加一个case,判断是否存在该事件。
代码如下:
8:微信消息的6大回复接口
(参考:微信公众平台开发文档---被动回复用户消息)
回复文本
/*
* 响应文本消息
* @param string $fromUsername 发送者标识
* @param string $toUsername 接受者标识
* @param string $content 响应文本内容
*/
public function sendText($fromUsername, $toUsername, $content)
{
$xmlData = '<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[%s]]></Content>
</xml>';
//脚下留心:传参时原来的发送者需要变成接受者
echo sprintf($xmlData, $fromUsername, $toUsername, time(), $content);
die;
}
回复图文
优化后的代码:
//调用
$newsData = array(
array('title' => 'a', 'desc'=>'aa', 'img'=>'http://网址/b.jpg', 'url' => '跳转url'),
array('title' => 'b', 'desc'=>'bb', 'img'=>'http://网址/e.png', 'url' => '跳转url'),
array('title' => 'c', 'desc'=>'cc', 'img'=>'http://网址/o.png', 'url' => '跳转url'),
array('title' => 'd', 'desc'=>'dd', 'img'=>'http://网址/e.png', 'url' => '跳转url'),
array('title' => 'e', 'desc'=>'ee', 'img'=>'http://网址/f.png', 'url' => '跳转url')
);
$this->sendNews($fromUsername, $toUsername, $newsData);
//封装
/*
* 响应文本消息
* @param string $fromUsername 发送者标识
* @param string $toUsername 接受者标识
* @param array $newsData 图片数据,格式( [ [title, desc, img, url], ...., [] ] )
*/
public function sendNews($fromUsername, $toUsername, $newsDatas)
{
$xmlData = '<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[news]]></MsgType>
<ArticleCount>'.count($newsDatas).'</ArticleCount>
<Articles>';
foreach ($newsDatas as $newsData)
{
$xmlData .= "<item>
<Title><![CDATA[{$newsData['title']}]]></Title>
<Description><![CDATA[{$newsData['desc']}]]></Description>
<PicUrl><![CDATA[{$newsData['img']}]]></PicUrl>
<Url><![CDATA[{$newsData['url']}]]></Url>
</item>";
}
$xmlData .= '</Articles>
</xml>';
echo sprintf($xmlData, $fromUsername, $toUsername, time());
die;
}
回复图片
/*
* 响应图片消息
* @param string $fromUsername 发送者标识
* @param string $toUsername 接受者标识
* @param string $MediaId 媒体ID
*/
public function sendImage($fromUsername, $toUsername, $MediaId = '获得的mediald')
{
$xmlData = '<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[image]]></MsgType>
<Image>
<MediaId><![CDATA[%s]]></MediaId>
</Image>
</xml>';
echo sprintf($xmlData, $fromUsername, $toUsername, time(), $MediaId);
die;
}
获得mediald方法
(开发者工具---在线接口调试工具)
先获取token:
1:接口列表选择获取access_token接口/token
2:参数列表中填写appid和secret(点击左下角【开发】菜单下【基本配置】菜单进入页面,里面有这两个参数)。
3:点击按钮获取access_token
注:提示IP问题则将IP复制粘贴到IP白名单即可,然后重新获取。
再获取mediald:
获取token后,再次进入到在线接口调试工具的页面,将token填入,选择好type,选择文件,点击检查问题就能获得mediaid。
回复视频
/*
* 响应视频消息
* @param string $fromUsername 发送者标识
* @param string $toUsername 接受者标识
* @param string $MediaId 媒体ID
*/
public function sendVideo($fromUsername, $toUsername, $MediaId = '')
{
$xmlData = '<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[video]]></MsgType>
<Video>
<MediaId><![CDATA[%s]]></MediaId>
<Title><![CDATA[%s]]></Title>
<Description><![CDATA[%s]]></Description>
</Video>
</xml>';
echo sprintf($xmlData, $fromUsername, $toUsername, time(),$MediaId, 'title', 'desc');
die;
}
回复音乐
/*
* 响应音乐消息
* @param string $fUname 发送者标识
* @param string $tUname 接受者标识
* @param string $MuUrl 音乐地址
* @param string $HQMuUrl 音乐地址(高清)
* @param string $ThMedId 媒体ID
*/
public function sendMusic($fUname, $tUname, $MuUrl, $HQMuUrl, $ThMedId = 'mediaid')
{
$xmlData = '<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[music]]></MsgType>
<Music>
<Title><![CDATA[音乐大放送]]></Title>
<Description><![CDATA[音乐描述]]></Description>
<MusicUrl><![CDATA[%s]]></MusicUrl>
<HQMusicUrl><![CDATA[%s]]></HQMusicUrl>
<ThumbMediaId><![CDATA[%s]]></ThumbMediaId>
</Music>
</xml>';
echo sprintf($xmlData, $fUname, $tUname, time(), $MuUrl, $HQMuUrl, $ThMediaId);
die;
}
9:常见报错解决方案
1:token验证失败
步骤1:检测接口直接在浏览器粘贴是否可以正常访问
步骤2:检测token和wxapi.php中是否一致
步骤3:检测wxapi.php是否调用的是valid方法
2:服务器故障
直接通过浏览器访问接口看有没有语法错误
没有错误就打印响应数据看格式是否有问题
需要响应的xml数据 file_put_contents()
网友评论