php 限制微信登陆,thinkphp 微信用户登录 设置问题

token信息在这个目录\application\Portal\Controller\WeixinController.class.php

微信公众号基本配置中 填写的URL需要正确响应微信发送的Token验证

URL一栏应该怎么写

55fd2b2273b5a8b4531f72773c469d6e.gif

QQ截图20200708165734.jpg (31.62 KB, 下载次数: 0)

2020-7-8 16:57 上传

WeixinController.class.php 内容如下

// +----------------------------------------------------------------------

// | ThinkCMF [ WE CAN DO IT MORE SIMPLE ]

// +----------------------------------------------------------------------

// | Copyright (c) 2013-2014 http://www.thinkcmf.com All rights reserved.

// +----------------------------------------------------------------------

// | Author: Dean

namespace Portal\Controller;

use Common\Controller\HomebaseController;

class WeixinController extends HomebaseController {

public function __construct() {

parent::__construct();

}

function _initialize() {

parent::_initialize();

import('Common.Lib.weixin');

$this->weixin = new \weixin($this->extract[weixin_appid],$this->extract[weixin_key],$this->extract[access_token]);

}

public function index() {

$data2['get']=$_GET;

$data2['post']=$_POST;

$data2['server']=$_SERVER;

//接收传送的数据

$fileContent = file_get_contents("php://input");

//转换为simplexml对象

$xmlResult = simplexml_load_string($fileContent, 'SimpleXMLElement', LIBXML_NOCDATA);

$xmlarray=json_decode(json_encode($xmlResult), true);

$data2['xml']=$xmlarray;

$data['msg']=json_encode($data2);

$data['time']=date('y-m-d H:i:s',time());

M('weixin')->add($data);

define("TOKEN", "zmm");

$echoStr = $_GET["echostr"];

if($this->checkSignature()){

if($xmlarray['Event']=='subscribe'){

$data=array();

$data['openid']=$xmlarray['FromUserName'];

if(!M('user')->where($data)->find()){

if(!M('openid')->where($data)->find()){

$data['code']=$xmlarray['EventKey'];

$data['time']=date('Y-m-d H:i:s',time());

M('openid')->add($data);

}

elseif($xmlarray['EventKey']){

$data['code']=$xmlarray['EventKey'];

$data['time']=date('Y-m-d H:i:s',time());

M('openid')->where(array('openid'=>$data['openid']))->save($data);

}

}

}

ob_clean();

echo $echoStr;

exit;

}

}

public function responseMsg()

{

//get post data, May be due to the different environments

$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

//extract post data

if (!empty($postStr)){

/* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection,

the best way is to check the validity of xml by yourself */

libxml_disable_entity_loader(true);

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

$fromUsername = $postObj->FromUserName;

$toUsername = $postObj->ToUserName;

$keyword = trim($postObj->Content);

$time = time();

$textTpl = "

%s

0

";

if(!empty( $keyword ))

{

$msgType = "text";

$contentStr = "Welcome to wechat world!";

$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);

echo $resultStr;

}else{

echo "Input something...";

}

}else {

echo "";

exit;

}

}

private function checkSignature()

{

// you must define TOKEN by yourself

if (!defined("TOKEN")) {

define("TOKEN", "zmm");

}

$signature = $_GET["signature"];

$timestamp = $_GET["timestamp"];

$nonce = $_GET["nonce"];

$token = TOKEN;

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

// use SORT_STRING rule

sort($tmpArr, SORT_STRING);

$tmpStr = implode( $tmpArr );

$tmpStr = sha1( $tmpStr );

if( $tmpStr == $signature ){

return true;

}else{

return false;

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值