ndfweb.cn

thinkphp实现微信登录授权、菜单、信息接收与处理


2021-05-29 10:11:16 (2859)


thinkphp 用第三方类库 wechat.class.php 实现微信菜单、微信信息接收与返回、微信网页登录静默授权和用户手动授权。主要是功能实现,帮助一些入门选手实现基本功能。 

thinkphp 用第三方类库 wechat.class.php 实现微信菜单、微信信息接收与返回、微信网页登录静默授权和用户手动授权。主要是功能实现,帮助一些入门选手实现基本功能。

    protected $AppID         = '';     // AppID(应用ID)    

    protected $AppSecret     = '';     // AppSecret

    protected $Token         = '';     // 微信后台填写的TOKEN

    protected $Crypt         = '';   // 消息加密KEY(EncodingAESKey)

    /*

     微信第三方开发者模式 使用方法

     服务器地址    : http://你的域名/index.php/Wx/wechat.html

     Token        : 自己定义

     AppID        : 微信公众账户后台的AppID

     AppSecret    : 微信公众账户后台的AppSecret

     Crypt        : 微信公众账户后台的EncodingAESKey

     */

    public function wechat(){

        // 第三方发送消息给公众平台

        $options = array(

                'token'                => $this->Token,         // 填写你设定的key

                'encodingaeskey'    => $this->Crypt,

                'appid'                => $this->AppID,

                'appsecret'            => $this->AppSecret,

                'debug'                => false,

                'logcallback'        => false,

            );

        import("@.Library.wechat");

        $weObj = new \Wechat($options);

        $weObj->valid();

        $type = $weObj->getRev()->getRevType();

        //设置菜单

        $newmenu =  array(

            "button"=>

                array(

                    array('type'=>'view','name'=>'客户案例','url'=>'http://www.vmonsion.com'),

                    array('name'=>'我的','sub_button'=>array(

                            array('type'=>'view','name'=>'我的网站','url'=>'http://www.vmonsion.com'),

                            array('type'=>'view','name'=>'个人资料','url'=>'http://www.vmonsion.com'),

                        )

                    ),

                    array('type'=>'view','name'=>'关于我们','url'=>'http://www.vmonsion.com/index.php'),

                    )

            );

        // 公众号菜单更新

        //$weObj->getMenu($newmenu);

        $weObj->createMenu($newmenu);

        //$weObj->deleteMenu($newmenu);

        //分解数据获得常用字段

        //$this->openid     = $weObj->getRev()->getRevFrom();

        $this->type     = $weObj->getRev()->getRevType();

        $this->data     = $weObj->getRev()->getRevData();

        $content = '[捂脸]'.$weObj->getRev()->getRevContent();

        switch($type) {

            // 文本消息

            case \Wechat::MSGTYPE_TEXT:

                    file_put_contents('test.txt','TextMessage',FILE_APPEND);

                    $weObj->text($content)->reply();

                    exit;

                    break;

            // 图片消息

            case \Wechat::MSGTYPE_IMAGE:

                    $weObj->text('This is a Picture?')->reply();

                    break;

            // 位置消息

            case \Wechat::MSGTYPE_LOCATION:

                    $weObj->text('what?GPS?')->reply();

                    exit;

                    break;

            // 连接消息

            case \Wechat::MSGTYPE_LINK:

                    break;

            // 音乐消息

            case \Wechat::MSGTYPE_MUSIC:

                    break;

            // 图文消息(推送过来的应该不存在这种类型,但是可以给用户回复该类型消息)

            case \Wechat::MSGTYPE_NEWS:

                    break;

            // 音频消息

            case \Wechat::MSGTYPE_VOICE:

                    break;

            // 视频消息

            case \Wechat::MSGTYPE_VIDEO:

                    break;

            // 短视频

            case \Wechat::MSGTYPE_SHORTVIDEO:

                    break;

            //事件消息:五种

            case \Wechat::MSGTYPE_EVENT:

                    $event = $weObj->getRev()->getRevEvent();

                    $reply = $this->messageEvent($event);

                    break;

            default:

                    $weObj->text("你好,我是微信小助手,很高兴为您服务~")->reply();

        }

    }

    // Wechat事件处理

    public function messageEvent($event){

        switch($event) {    

            // 订阅        

            case \Wechat::EVENT_SUBSCRIBE:

                break; 

            // 取消订阅    

            case \Wechat::EVENT_UNSUBSCRIBE:

                break;

            // 扫描带参数二维码        

            case \Wechat::EVENT_SCAN:

                break;  

            // 上报地理位置         

            case \Wechat::EVENT_LOCATION:

                break;

            // 菜单 - 点击菜单跳转链接     

            case \Wechat::EVENT_MENU_VIEW:

                break;

            // 菜单 - 点击菜单拉取消息

            case \Wechat::EVENT_MENU_CLICK:

                break;

            // 菜单 - 扫码推事件(客户端跳URL)    

            case \Wechat::EVENT_MENU_SCAN_PUSH:

                break;

            // 菜单 - 扫码推事件(客户端不跳URL)

            case \Wechat::EVENT_MENU_SCAN_WAITMSG:

                break;

            // 菜单 - 弹出系统拍照发图

            case \Wechat::EVENT_MENU_PIC_SYS:

                break;

            // 菜单 - 弹出拍照或者相册发图

            case \Wechat::EVENT_MENU_PIC_PHOTO:

                break;

            // 菜单 - 弹出微信相册发图器

            case \Wechat::EVENT_MENU_PIC_WEIXIN:

                break;

            // 菜单 - 弹出地理位置选择器

            case \Wechat::EVENT_MENU_LOCATION:

                break;

            default:

                    break;

        }

    }

复制代码

/* 微信登录验证,可以选择方法一(静默授权)或者方法二(用户手动授权)

       1、设置微信公众号的菜单,访问 http://你的域名/index.php/Wx/checkLogin.html 

       2、返回redirect_uri的授权域名,获取$_GET['code']

       3、通过code换取网页授权access_token和openID

       4、function loginWx() 就是最终获取数据的方法

     */     

    public function checkLogin(){

        // 方法一 Scope为snsapi_base基本授权

        $result = $this->_baseAuth("http://www.kodjr.com/index.php/Wx/loginWx.html");

        

        // 方法二 Scope为snsapi_userinfo用户授权

        //$result = $this->_userInfoAuth("http://www.kodjr.com/index.php/Wap/loginWx.html");

    }

    

    // 验证是否邦定帐号了

    public function loginWx(){

        $code = $_GET['code'];

        // 方法一

        $tokenOpenID = $this->_baseToken($code);

        ///dump($tokenOpenID);

        // 设置session

        if(!session('user_wechat_auth')){

            session('user_wechat_auth', $tokenOpenID);

        }else{

                

        }    

        // 方法二

        //$userData = $this->_userInfoToken($code);

        //$userInfo = $this->_getUserInfo($userData['access_token'],$userData['openid']);            

    }

    

    

    // 方法一:Scope为snsapi_base基本授权

    public function _baseAuth($redirect_url){  

        // 1.准备scope为snsapi_base网页授权页面  

        $baseurl = urlencode($redirect_url);  

        $snsapi_base_url = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='.$this->AppID.'&redirect_uri='.$baseurl.'&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect';  

        // 2.静默授权,获取code 

        $code = $_GET['code'];

        if( !isset($code) ){  

            header('Location:'.$snsapi_base_url);  

        }

    }

    public function _baseToken($code){

        // 3.通过code换取网页授权access_token和openID  

        $curl = 'https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$this->AppID.'&secret='.$this->AppSecret.'&code='.$code.'&grant_type=authorization_code';  

        $content = $this->http_curl($curl);  

        $result = json_decode($content[1],true);  

        $result['state'] = $content[0];

        return $result;      

    }

    

    // 方法二:Scope为snsapi_userinfo用户授权

    public function _userInfoAuth($redirect_url){  

        //1.准备scope为snsapi_userInfo网页授权页面  

        $redirecturl = urlencode($redirect_url);  

        $snsapi_userInfo_url = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='.$this->AppID.'&redirect_uri='.$redirecturl.'&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect';  

        //2.用户手动同意授权,同意之后,获取code  

        $code = $_GET['code'];  

        if( !isset($code) ){  

            header('Location:'.$snsapi_userInfo_url);  

        }  

    }

    public function _userInfoToken($code){

        //3.通过code换取网页授权access_token  

        $curl = 'https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$this->AppID.'&secret='.$this->AppSecret.'&code='.$code.'&grant_type=authorization_code';  

        $content             = $this->http_curl($curl);  

        $result = json_decode($content[1],true);  

        $result['state'] = $content[0];

        //4.通过access_token和openid拉取用户信息  

        $webAccess_token     = $result->access_token;  

        $openid             = $result->openid;  

        $userInfourl         = 'https://api.weixin.qq.com/sns/userinfo?access_token='.$webAccess_token.'&openid='.$openid.'&lang=zh_CN ';  

        $recontent             = $this->http_curl($userInfourl); 

        $userInfo             = json_decode($recontent,true);  

        return $userInfo;  

    }  

    public function http_curl($url, $method='POST', $postfields = null, $headers = array(), $debug = false)

    {

        $ci = curl_init();

        /* Curl settings */

        curl_setopt($ci, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1);

        curl_setopt($ci, CURLOPT_CONNECTTIMEOUT, 30);

        curl_setopt($ci, CURLOPT_SSL_VERIFYPEER, FALSE);

        curl_setopt($ci, CURLOPT_SSL_VERIFYHOST, FALSE);

        curl_setopt($ci, CURLOPT_TIMEOUT, 30);

        curl_setopt($ci, CURLOPT_RETURNTRANSFER, true);

        switch ($method) {

            case 'POST':

                curl_setopt($ci, CURLOPT_POST, true);

                if (!empty($postfields)) {

                    curl_setopt($ci, CURLOPT_POSTFIELDS, $postfields);

                    $this->postdata = $postfields;

                }

                break;

        }

        curl_setopt($ci, CURLOPT_URL, $url);

        curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);

        curl_setopt($ci, CURLINFO_HEADER_OUT, true);

        $response = curl_exec($ci);

        $http_code = curl_getinfo($ci, CURLINFO_HTTP_CODE);

        if ($debug) {

            echo "=====post data======\r\n";

            var_dump($postfields);

            echo '=====info=====' . "\r\n";

            print_r(curl_getinfo($ci));

            echo '=====$response=====' . "\r\n";

            print_r($response);

        }

        curl_close($ci);

        return array($http_code, $response);

    }

————————————————

版权声明:本文为CSDN博主「Alvin_扣扣953821815」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/m0_37412958/article/details/78442304


了解更多请访问:http://www.ndfweb.cn/news-862.html
  NDF俱乐部
  国际域名注册
  建站咨询
合作伙伴:万网 | 新网 | 新网互联 NDF网站建设淘宝店 | 实用工具 | 外貿網站建設 | 联系我们
鲁公网安备 37110202000336号 鲁ICP备2021027697号-1 Sitemap - RSSRSS订阅