WordPress网站连接微信公众号除了安装WordPress插件外,还有哪些技巧呢?

WordPress网站连接微信公众号除了安装WordPress插件外,还有哪些技巧呢?

3
2020-01-15 15:57:10

微信公众号当前是每个用户都在使用的功能,而使用wordpress程序的站长会希望把自己的网站连接到微信公众号。连接后通过公众号访问网站的内容。那么WordPress网站连接微信公众号除了安装WordPress插件外,还有哪些技巧呢?

对于许多不想安装插件的站长而言。插件是能少则少(可能是个人癖好)。再说现在的微信机器人 5.0 版本对服务器要求较高,只支持 Linux 服务器,PHP 要求 7.2 ,服务器支持 Memcached。还需要额外安装插件WPJAM,看到这里可能有很多小站长只能望而却步了。

这里为大家介绍的是只用简单代码把WP和公众号连接的方法,不用插件操作简单,缺点功能相对较少,连接后可以实现公众号通过关键字调取网站内容,搜索文章,对于许多站长来说已经足够用了,让你的公众号不在缺少内容,

安装方法:

一、下载代码文件,修改代码内的信息

1.是将代码中的数据库链接信息,改成你WordPress的数据库链接信息

2.默认的token为weixin,可修改为自己的token,需要与微信公众号后台的token对应

二、将修改好文件上传至wp网站内的任意目录

三、进入微信公众号平台-基本配置-服务器配置-设置里面设置对接信息

提交后就可以实现wordpress网站与微信公众号的对接功能了。

此代码只是简单连接到微信公众号,并不支持后台操作功能

代码如下:

<?php
//上传到根目录,公众平台验证https://xxx.com/weinxin.php
//获取数据并排序
$timestamp=$_GET['timestamp'];
$nonce=$_GET['nonce'];
$token='weixin'; //此处添加TOKEN值需要与公众号值相同
$signature=$_GET['signature'];
$array = array($timestamp,$nonce,$token);
sort($array);
//拼接数据并sha1加密
$tmpstr=implode('', $array);
$tmpstr=sha1($tmpstr);
//数据验证
if($tmpstr==$signature && $_GET['echostr']){
echo $_GET['echostr'];
exit;
}else{
reponseMsg();
}
function reponseMsg(){
$postArr=file_get_contents('php://input');
$postObj=simplexml_load_string($postArr);
if(strtolower($postObj->MsgType)==’event’){
if(strtolower($postObj->Event)==’subscribe’){
$toUser=$postObj->FromUserName;
$fromUser=$postObj->ToUserName;
$time=time();
$MsgType=’text’;
$content=”欢迎关注\n请直接回复关键字检索文章\n也可直接进入<a href='https://www.xxxx.com' target="_blank"  rel="nofollow" >xxxx网</a>“;//此处添加公众号关注的欢迎信息
$template=” <xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<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;
}
}
if(strtolower($postObj->MsgType)==’text’){
$postcontent=$postObj->Content;
$conn=mysqli_connect(‘localhost’,’数据库用户名’,’数据库密码’,’数据库名’);//此处修改数据库链接信息,请正确填写
$sql = “select * from wp_posts where post_title like ‘%$postcontent%’ and post_status=’publish'”;
$result = mysqli_query($conn,$sql);
$row=mysqli_fetch_all($result,MYSQLI_ASSOC);
$toUser=$postObj->FromUserName;
$fromUser=$postObj->ToUserName;
$time=time();
if(count($row) <= 8 && count($row) != 0){
$MsgType='news';
$template ='<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<ArticleCount>%s</ArticleCount>
<Articles>‘;
foreach ($row as $key => $value) {
$template .=”<item>
<Title><![CDATA[".$value['post_title']."]]></Title>
<Description><![CDATA[点击查看]]></Description>
<PicUrl><![CDATA[https://logo.png]]></PicUrl>
<Url><![CDATA[".$value['guid']."]]></Url>
</item>“;
}
$template .=’</Articles>
</xml>‘;
$info=sprintf($template,$toUser,$fromUser,$time,$MsgType,count($row));
echo $info;
}else if(count($row) == 0){
$MsgType=’text’;
$content=’暂未检索到相关文章,请换个关键字试试’;
$template=” <xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<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;
}else{
$MsgType=’text’;
$content=’符合关键字的文章太多,请多输入几个字再次检索’;
$template=” <xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<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;
}
mysqli_close($conn);

}
}
?>

 

喜欢这个文章就点个赞分享给好友吧~

END

发表评论

一次支付终身使用
免费版本更新
靠谱的技术支持