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

coldplay.xixi
풀어 주다: 2020-06-09 12:04:11
앞으로
3019명이 탐색했습니다.

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으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿