那浓雾,抓一把,软绵绵;吸一口,甜津津;踩一脚,轻悠悠。既然都是风景,何必纠结与下不去的站,互不干扰,各自安好。
本文实例讲述了基于thinkPHP3.2实现微信接入及查询token值的方法。分享给大家供大家参考,具体如下:
1.在con.fig文件里面配置TOKEN,APPID,APPSECRET值
2.控制器WeixinController代码:
<?php /** * 微信父类控制器 * @author Songle * */ namespace Weixin\Controller; use Think\Controller; class WeixinController extends Controller { private $last_time=null; private $appid=null; private $appsecret=null; function __construct(){ parent::__construct(); $token=C('TOKEN'); $this->appid=C('APPID'); $this->appsecret=C('APPSECRET'); //获取微信服务器GET请求的4个参数 $signature = I('signature'); $timestamp = I('timestamp'); $nonce = I('nonce'); $echostr = I('echostr'); if (! empty ( $echostr) && ! empty ( $signature ) && ! empty ($nonce )) { //定义一个数组,存储其中3个参数,分别是timestamp,nonce和token $tempArr = array($nonce,$timestamp,$token); //进行排序 sort($tempArr,SORT_STRING); //将数组转换成字符串 $tmpStr = implode($tempArr); //进行sha1加密算法 $tmpStr = sha1($tmpStr); //判断请求是否来自微信服务器,对比$tmpStr和$signature if($tmpStr == $signature) { echo $echostr; } exit(); } } /** * 获取tooken值 */ public function getTooken(){ $this->last_time = 1448012924; $access_token = "填写上一次的token值"; //需要替换成自己的 if(time() > ($this->last_time + 7200)) { //GET请求的地址 $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$this->appid}&secret={$this->appsecret}"; $access_token_Arr = $this->https_request($url); $this->last_time = time(); return $access_token_Arr['access_token']; } return $access_token; } //https请求(支持GET和POST) public function https_request($url,$data = null) { $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); if(!empty($data)) { curl_setopt($ch,CURLOPT_POST,1); //模拟POST curl_setopt($ch,CURLOPT_POSTFIELDS,$data); //POST内容 } $outopt = curl_exec($ch); curl_close($ch); $outopt = json_decode($outopt,true); return $outopt; } }
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
以上就是基于thinkPHP3.2如何实现微信接入及查询token值的方法。这年头不缺爱情,缺的是把爱情当回事的人。更多关于基于thinkPHP3.2如何实现微信接入及查询token值的方法请关注haodaima.com其它相关文章!