php微信公众号连接打印机,微信公众号连接thinkphp5

在简书找了找,没发现有微信连接tp5的文章,于是干脆在自己连接的同时,写一份笔记

首先

你得有一个微信公众号或者订阅号(当然,测试号也可以);

然后

你还得拥有一个服务器,可以自己买,也可以在新浪云(SAE)啊,腾讯云之类的;

其三

当拥有了自己的服务器以后,下载一个tp5的框架,放入自己的服务器里;下载地址:http://www.thinkphp.cn/down.html

正式开始

在app的index控制器下的index方法里(当然,写哪里都可以,自己乐意就好),写上代码namespace app\index\controller;

class Index {

public function Index(){

//验证消息

if(isset($_GET['echostr'])){ //微信服务器和你的服务器第一次通讯会带上echostr

$echoStr = $_GET["echostr"];

if($this->checkSignature()){

header('content-type:text');

echo $echoStr;

exit;

}

}else{

Loader::import('Wechat.wechatCallbackapiTest');

$wechatCallbackapiTest = new \wechatCallbackapiTest();

$wechatCallbackapiTest -> responseMsg();

}

//检查签名

private function checkSignature()

{

$signature = $_GET["signature"];

$timestamp = $_GET["timestamp"];

$nonce = $_GET["nonce"];

$token = '123456798';

$tmpArr = array($token, $timestamp, $nonce);

sort($tmpArr, SORT_STRING);

$tmpStr = implode($tmpArr);

$tmpStr = sha1($tmpStr);

if($tmpStr == $signature){

return true;

}else{

return false;

}

}

//响应消息

public function responseMsg()

{

$postStr =  isset($GLOBALS["HTTP_RAW_POST_DATA"]) ?  $GLOBALS["HTTP_RAW_POST_DATA"]  : "" ;

if (!empty($postStr)){

$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);

$RX_TYPE = trim($postObj->MsgType);

switch ($RX_TYPE)

{

case "event":

$result = $this->receiveEvent($postObj);

break;

case "text":

$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;

}

echo $result;

}

}

它的意思是,当微信第一次与我们的服务器通讯时,会带上echostr,所以调用checkSignature的方法去与微信验证是否匹配,当匹配了以后,再次通讯就不会带上echostr了,这时我们就调用responseMsg方法去对用户操作发生的事件进行响应。文章结尾会附上关于微信的基础接口和高级接口(用tp5的话,要文件名和类名对应,自行进行引用)

将我们设置的token(比如‘123456798’)填入微信配置的token,写上对应的url,基本上是可以验证成功的

注意:第一次验证的时候我们的config不能将调试模式打开,会配置失败。解决方法是先关掉调试,token验证成功以后再开启调试模式。

以下是基础接口,不保证不会报错,因为我也是从网上找过来的:::链接: https://pan.baidu.com/s/1ghcpaxl

密码: qi3m

高级接口(同上)::::链接: https://pan.baidu.com/s/1jKgoNFw

密码: am2u

接口文件我是放在extend内自建的一个wechat文件夹里,tp5用Loader::import('Wechat.wechatCallbackapiTest');

就可以很方便的引用。

自定义菜单参考:http://qydev.weixin.qq.com/wiki/index.php?title=%E5%88%9B%E5%BB%BA%E5%BA%94%E7%94%A8%E8%8F%9C%E5%8D%95

有错勿怪,我毕竟也是个初学者...

以上。

高级接口已更新

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值