2019-3-28 15:09:02更新:
感谢各位的支持。最早发帖是在大四毕业论文期间,所以针对第一次接触微信公众号的学生。时过境迁,4年过去了,在微信上遇到了方方面面的问题,这里贡献些自己的学习资料,供大家更上一层楼!
一,初学者:可以买《方倍工作室-微信公众号开发php版》(非广告),php简单易学好上手,我的php是幕课网自学的(php由入门到精通)。按照书里的内容稳步研究。期间需要学习到 “服务器搭建(推荐 阿里云香港1核1G1M centos),php控制面板安装(推荐appnode,宝塔);域名购买(阿里云)解析和绑定(国内服务器需备案域名,所以使用香港地区);代码编写上传(按书或博文自己捣鼓);公众号申请(尽量搞到认证服务号或服务号,不要订阅号):微信接口主要分两类:接口类和消息类——认证服务号可使用微信登陆等接口类功能,非认证号可使用消息类功能(比如自定义菜单那、自定义回复和扫码关注),这系列博文针对的都是消息类功能。
二,入门者:最好能有可用的认证服务号和微信商户,不然没法玩。代码上,若使用tp5或laravel或可以使用github开源包的php框架,推荐EasyWechat包,该包集成了几乎所有类型公众号的所有功能,不需要自己研究太多微信功能,会调用即可。
其它微信的框架,例如weiphp或微擎,不好用。如果只是给自己系统增加个微信功能,用easywechat或者自己系统封装的微信类包;如果纯做微信开发,推荐weiphp。
有问题发邮件: [email protected]
=============================以下为旧内容========================
前面两篇详细讲解了微信收发消息的“万能代码”,今天开点小荤,用MySql数据表实现关键字回复。
老规矩,声明背景:
1.我使用的是BAE3.0扩展服务中的MySql数据库,
2.关键词回复代码 是在 微信核心页代码的基础上修改的
3.使用数据库作为关键字回复适用于开发者模式下关键字非常多的情形,如果公众平台没有太多关键字,就不需要;使用数据库就不需要频繁修改代码了。
4.以下代码的局限性:不适合回复 多图文消息,因为一次只查询出一条结果。
========================================华丽丽的分割线==================================================
//接收文本消息
private function receiveText($object)
{
include './conn/conn.php';//连接数据库
mysql_set_charset("utf8");//设置字符集,没有测试是否必须。科普:微信服务器采用utf8,所以MySql数据库字符集是utf8_general_ci。
$keyword = $object->Content;//获取关键字
$rs = mysql_query("select * from guanjiancihuifu where keywords='$keyword'",$link);//查询数据
$info = mysql_fetch_array($rs);//将查询到的数据填充到数组
if(!$rs)
{
$content="词库中没有这个词,查询失败!\nBy阿凡舟舟"; //$rs为空
}
else
{ //获取查询到的结果;[]内的为数据表列名
$type = $info[type]; //回复消息类型——text,image,voice,video,music,news
$contentStr = $info[content]; //文本消息
$Title = $info[title];
$Description = $info[description];//单图文消息
$PicUrl = $info[picurl];
$Url = $info[url];
$MusicUrl = $info[musicurl]; //音乐消息
$HQMusicUrl = $info[hqmusicurl];
switch ($type)//这里我设置一列为type,借以区分回复消息的类型
{
case "text":
$content = $contentStr; //文本消息
break;
case "news": //这里的news仅代表单图文
$content = array();
$content[] = array("Title"=>$Title, "Description"=>$Description, "PicUrl"=>$PicUrl, "Url" =>$Url);
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 "music":
$content = array("Title"=>$Title, "Description"=>$Description, "MusicUrl"=>$MusicUrl, "HQMusicUrl"=>$HQMusicUrl);
break;
default:
$content = "该关键词还没有收录词库。请从菜单获取信息\n\n".date("Y-m-d H:i:s",time())."\nBy阿凡舟舟";
break;
}//switch
mysql_close($link);
}//else
if(is_array($content)){//TODO 如果发过来的是图片链接或音乐链接。。。
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;
}
数据表内容
==============================================期间遇到的问题===============================================================
1.为了代码的美观,我把关键字查询代码片段放在了guanjianzi.php文件,在微信核心页include过来。下面是代码
结果微信公众平台测试出现:该公众号暂时无法提供服务...
解决办法:把代码放在微信核心页。
经验教训:在一个页面中写的代码和include另一个页面中同样的代码,还是有很大差别的。数据的交叉传递造就了服务的无法运行。
2.php页面在zend studio 浏览器运行时,从数据库中获取的数据是乱码。
解决办法:在页面首添加 mysql_set_charset("utf8");
保证软件设置字符集为urf-8
设置在外部浏览器中浏览(貌似这个最有用)。
到现在我的查询数据库结果在zend studio浏览器中还是乱码。。但在微信公众号查询图书就没有乱码——很明显,内部浏览器编码不是utf-8,估计是gbk2312。
=========================================================================================================================
扩展:使用循环语句输出查询结果,多图文貌似就有救了呢,么么哒!
介绍到此。
2016-11-10 16:22:00更新:
数据库资源下载地址:http://download.csdn.net/detail/afanxingzhou/9679126