>PHP 프레임워크 >ThinkPHP >Thinkphp3.2 기반의 QQ 타사 인증 로그인 확장 클래스

Thinkphp3.2 기반의 QQ 타사 인증 로그인 확장 클래스

coldplay.xixi
coldplay.xixi앞으로
2020-06-09 09:34:233091검색

Thinkphp3.2 기반의 QQ 타사 인증 로그인 확장 클래스

Thinkphp3.2 기반 QQ 타사 인증 로그인 확장 클래스

Thinkphp3.2 기반 QQ 타사 인증 로그인 확장 클래스 실제로 다음 클래스도 수집 및 컴파일됩니다. TP 공식 웹사이트에서 가져온 내용을 약간 수정하고 개선했습니다.

여기서 "/Application/Common/Lib/Qqconnect.class.php"에 파일을 넣었습니다. (실제로 이 파일 경로는 각자의 취향에 따라 배치할 수 있습니다.)

Instantiation

$Qqconnect = new \Common\Lib\Qqconnect();

__construct 메소드에서 app_id, app_key, 콜백 주소를 직접 작성할 수 있습니다
또한 매개변수를 전달하도록 코드를 변경할 수도 있습니다. 자신의 기본 설정에 따라 또는 구성 파일에 쓰십시오.

호출 방법:

1. qq의 로그인 버튼 메서드에서 getAuthCode 메서드를 호출합니다.

$qqobj=new \Org\Util\Qqconnect();
$qqobj->getAuthCode();

2. 콜백 주소 메서드

$qqobj=new \Org\Util\Qqconnect();
$result=$qqobj->getUsrInfo();

에서 getUsrInfo 메서드를 호출합니다.

3. Scope는 필요에 따라 get_user_info, list_album, upload_pic, do_like 값을 추가합니다.

Qqconnect.class.php

<?php
// +----------------------------------------------------------------------
// | Copyright (c) 2015.
// +----------------------------------------------------------------------
// | Author: qiandutianxia <852997402@qq.com>
// +----------------------------------------------------------------------
namespace Common\Lib;
/**
 *  qq第三方登录认证
 */
class Qqconnect {
    private static $data;
    //APP ID
    private $app_id="";
    //APP KEY
    private $app_key="";
    //回调地址
    private $callBackUrl="";
    //Authorization Code
    private $code="";
    //access Token
    private $accessToken="";
    private $openid="";
 
    public function __construct(){
        $this->app_id="";
        $this->app_key="";
        $this->callBackUrl=""; //你的回调地址
        //检查用户数据
        if(empty($_SESSION[&#39;QC_userData&#39;])){
            self::$data = array();
        }else{
            self::$data = $_SESSION[&#39;QC_userData&#39;];
        }
    }
 
 
    //获取Authorization Code
    public function getAuthCode(){
        $url="https://graph.qq.com/oauth2.0/authorize";
        $param[&#39;response_type&#39;]="code";
        $param[&#39;client_id&#39;]=$this->app_id;
        $param[&#39;redirect_uri&#39;]=$this->callBackUrl;
 
        //生成唯一随机串防CSRF攻击
        $state = md5(uniqid(rand(), TRUE));
        $_SESSION[&#39;state&#39;]=$state;
        $param[&#39;state&#39;]=$state;
        $param[&#39;scope&#39;]="get_user_info";
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        header("Location:".$url);
    }
 
    //通过Authorization Code获取Access Token
    private function _getAccessToken(){
        $this->code=$_GET[&#39;code&#39;];
        $url="https://graph.qq.com/oauth2.0/token";
        $param[&#39;grant_type&#39;]="authorization_code";
        $param[&#39;client_id&#39;]=$this->app_id;
        $param[&#39;client_secret&#39;]=$this->app_key;
        $param[&#39;code&#39;]=$this->code;
        $param[&#39;redirect_uri&#39;]=$this->callBackUrl;
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        return $this->getUrl($url);
    }
 
    //获取openid
    public function _setOpenID(){
        $rzt=$this->_getAccessToken();
        parse_str($rzt,$data);
        $this->accessToken=$data[&#39;access_token&#39;];
        $url="https://graph.qq.com/oauth2.0/me";
        $param[&#39;access_token&#39;]=$this->accessToken;
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        $response=$this->getUrl($url);
 
        //--------检测错误是否发生
        if(strpos($response, "callback") !== false){
            $lpos = strpos($response, "(");
            $rpos = strrpos($response, ")");
            $response = substr($response, $lpos + 1, $rpos - $lpos -1);
        }
        $user = json_decode($response);
 
        if(isset($user->error)){
            exit("错误代码:100007");
        }
         
        return $user->openid;
    }
 
 
    //获取信息
    public function getUserInfo(){
        if($_GET[&#39;state&#39;] != $_SESSION[&#39;state&#39;]){
            exit("错误代码:300001");
        }
 
        $openid=$this->_setOpenID();
        if(empty($openid)){
            return false;
        }
        session(&#39;openid&#39;,$openid);
        $url="https://graph.qq.com/user/get_user_info";
        $param[&#39;access_token&#39;]=$this->accessToken;
        $param[&#39;oauth_consumer_key&#39;]=$this->app_id;
        $param[&#39;openid&#39;]=$openid;
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        $rzt=$this->getUrl($url);
        return $rzt;
    }
 
    public function getOpenId(){
        if($_GET[&#39;state&#39;] != $_SESSION[&#39;state&#39;]){
            exit("错误代码:300001");
        }
        $rzt=$this->_getAccessToken();
        parse_str($rzt,$data);
        $this->accessToken=$data[&#39;access_token&#39;];
        $url="https://graph.qq.com/oauth2.0/me";
        $param[&#39;access_token&#39;]=$this->accessToken;
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        $response=$this->getUrl($url);
 
        //--------检测错误是否发生
        if(strpos($response, "callback") !== false){
            $lpos = strpos($response, "(");
            $rpos = strrpos($response, ")");
            $response = substr($response, $lpos + 1, $rpos - $lpos -1);
        }
        $info = object_array(json_decode($response));
        $qq[&#39;access_token&#39;] = $this->accessToken;
        $qq[&#39;openid&#39;]       = $info[&#39;openid&#39;];
        session(&#39;qq&#39;,$qq);
        return $info[&#39;openid&#39;];
    }
 
 
    public function getInfo($openid=&#39;&#39;,$accessToken=&#39;&#39;){
        $url="https://graph.qq.com/user/get_user_info";
        $param[&#39;oauth_consumer_key&#39;]=$this->app_id;
        $param[&#39;access_token&#39;]=$accessToken;
        $param[&#39;openid&#39;]=$openid;
        $param =http_build_query($param,&#39;&#39;,&#39;&&#39;);
        $url=$url."?".$param;
        $rzt=$this->getUrl($url);
        $info = object_array(json_decode($rzt));
        return $info;
    }
 
 
    //CURL GET
    private function getUrl($url){
        $ch = curl_init($url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 5);
        if (!empty($options)){
            curl_setopt_array($ch, $options);
        }
        $data = curl_exec($ch);
        curl_close($ch);
        return $data;
    }
 
 
    //CURL POST
    private function postUrl($url,$post_data){
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
        ob_start();
        curl_exec($ch);
        $result = ob_get_contents();
        ob_end_clean();
        return $result;
    }
}

다음은 컨트롤러에 있는 코드입니다

LoginController.class.php 이 파일은 주로 2가지 메소드를 담고 있습니다

QQ 로그인 시 접속되는 주소를 클릭하세요

public function qq_login(){
        $Qqconnect = new \Common\Lib\Qqconnect();
        $Qqconnect->getAuthCode();
    }

콜백 접속 주소

public function callback(){
        $Qqconnect = new \Common\Lib\Qqconnect();
        $openid = $Qqconnect->getOpenId();
        $qq = session(&#39;qq&#39;);
 
 
 
        $Member = M(&#39;Member&#39;);
        $map = array();
        $map[&#39;openid&#39;] = $openid;
        $userInfo = $Member->where($map)->find();
 
 
        if(!empty($userInfo)){
            $this->success(&#39;登陆成功!&#39;,U(&#39;Member/index&#39;));
        }else{
            $Qqconnect = new \Common\Lib\Qqconnect();
            $userInfo = $Qqconnect->getInfo($qq[&#39;openid&#39;],$qq[&#39;access_token&#39;]);
            print_r($userInfo);
            exit;
    }

위 내용은 간단한 예시이므로 수정 및 개선 전 참고하시기 바랍니다. 이해가 안되는 부분이 있으면 토론을 위해 메시지를 남길 수 있습니다.

추천 튜토리얼: "PHP 비디오 튜토리얼"

위 내용은 Thinkphp3.2 기반의 QQ 타사 인증 로그인 확장 클래스의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 liqingbo.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제