这几天发的都是验证过之后,就是服务器已经接管微信公众号的帖子,忽略了大家这一点,怪我了..今天给大家发布一个服务器验证token,能是服务器接管微信的方法,用tp开发的越来越上手了,给大家看看,虽然很简单,但是我觉得好多人不会,就多此一举的发一下,希望大佬有时间可以教教我用tp3.2.3 最近确实学不转 感觉跟我最喜欢的laravel完全不在一个位面.谢谢大佬
<?php
//这两个控制器是我本来就有的这里就不做演示 可以不继承 这个控制器用到的东西 不依靠外面的东西
namespace Apps\Controller;
use Common\Controller\AppBaseController;
/**
* 首页
*/
define("TOKEN", "");//定义你公众号自己设置的token
define("APPID", "");//填写你微信公众号的appid 千万要一致啊
define("APPSECRET", "");//填写你微信公众号的appsecret 千万要记得保存 以后要看的话就只有还原了 保存起来 有益无害
class WeChatController extends AppBaseController
{
//判断是介入还是用户 只有第一次介入的时候才会返回echostr
function index()
{
//这个echostr呢 只有说验证的时候才会echo 如果是验证过之后这个echostr是不存在的字段了
$echoStr = $_GET["echostr"];
if ($this->checkSignature()) {
echo $echoStr;
//如果你不知道是否验证成功 你可以先echo echostr 然后再写一个东西
exit;
}
}//index end
//验证微信开发者模式接入是否成功
private function checkSignature()
{
//signature 是微信传过来的 类似于签名的东西
$signature = $_GET["signature"];
//微信发过来的东西
$timestamp = $_GET["timestamp"];
//微信传过来的值 什么用我不知道...
$nonce = $_GET["nonce"];
//定义你在微信公众号开发者模式里面定义的token
$token = "xiaochen";
//三个变量 按照字典排序 形成一个数组
$tmpArr = array(
$token,
$timestamp,
$nonce
);
// use SORT_STRING rule
sort($tmpArr, SORT_STRING);
$tmpStr = implode($tmpArr);
//哈希加密 在laravel里面是Hash::
$tmpStr = sha1($tmpStr);
//按照微信的套路 给你一个signature没用是不可能的 这里就用得上了
if ($tmpStr == $signature) {
return true;
} else {
return false;
}
}// checkSignature end
//构建一个发送请求的curl方法 微信的东西都是用这个 直接百度
function https_request($url, $data = null)
{
//这个方法我不知道是怎么个意思 我看都是这个方法 就copy过来了
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)){
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}//https_request end
} //classend
注释什么的我觉得都很全了 大家不懂的可以加小陈QQ1098765230 直接上来就是问就行了 最近比较忙 可能回复不是很及时 大家不要介意哈