1. 程式人生 > >第三方登入開發流程詳解

第三方登入開發流程詳解

首先你得是服務號,並且是經過認證的.這樣微信會給你很多第三方介面的許可權,如果是訂閱號或者沒有認證的服務號那就不用想了!

一、開啟開發者模式

開始你需要進入微信公眾平臺開啟開發模式,並且填寫oauth2的回撥地址,地址填寫你專案的域名就可以了.比如:www.baidu.com或zhidao.baidu.com.如果你的專案在二級域名就寫二級域名,前端url授權地址,在url中填寫appid與你專案中方法中的oauth的地址,具體在下面的程式碼中可以看到.

<a href="https://open.weixin.qq.com/connect/oauth2/authorize?appid=appid&redirect_uri=http://www.xxxxxx.com/action/function/oauth2&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect">授權</a>


再說後臺邏輯,首先呼叫微信介面的SDK.(後面會有)

include('class_weixin_adv.php');

之後填入微信官方給的的appid與secret

$weixin=new class_weixin_adv("appid", "secret");

初始化SDK的類,取到code,利用獲取到的code在獲取出openid 看下面程式碼註釋!

$url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=".$_GET['code']."&grant_type=authorization_code";
$res = $weixin->https_request($url);//呼叫SDK方法獲取到res 從中可以得到openid
$res=(json_decode($res, true));//轉換成array 方便呼叫openid

繼續呼叫SDK方法,獲取到使用者資訊.此時$row已經獲得使用者資訊了 可以var_dump下看看鍵值方便存入資料庫

$row=$weixin->get_user_info($res['openid']);

獲取使用者資訊就大功告成了,但這還不夠.我們需要的是無需註冊!所以需要利用openid,openid屬於唯一憑證,每個使用者對不同的公眾號都有不同的openid.可以理解成使用者賬號的感覺.我這裡用的是把openid存入cookie的解決方案,類似使用者登陸的感覺,一些關鍵資料驗證只需要與資料庫中的openid進行對比.其他的一些利用方法可以發揮大家的想象!可以跟我留言交流!

關於之前的a連結的授權,大家也可以判斷cookie是否存在openid,從而讓未授權使用者直接跳轉到該地址,省卻了使用者的一步操作.

下面是完整邏輯程式碼,大家可以參考下!

public function oauth2(){
           include('class_weixin_adv.php');
            $weixin=new class_weixin_adv("appid", "secret");
            if (isset($_GET['code'])){
                $url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=".$_GET['code']."&grant_type=authorization_code";
                $res = $weixin->https_request($url);
                $res=(json_decode($res, true));
                $row=$weixin->get_user_info($res['openid']);
                
                if ($row['openid']) {
                   //這裡寫上邏輯,存入cookie,資料庫等操作
                    cookie('weixin',$row['openid'],25920000);
                   
                }else{
                    $this->error('授權出錯,請重新授權!');
                }
            }else{
                echo "NO CODE";
            }
            $this->display();
        }

SDK程式碼:微信官方有手冊,我就不多講了,自己研究,很簡單的!.

<?php
/**
 * 微信SDK 
 */
class class_weixin_adv
{
    var $appid = "";
    var $appsecret = "";

    //建構函式,獲取Access Token
    public function __construct($appid = NULL, $appsecret = NULL)
    {
        if($appid){
            $this->appid = $appid;
        }
        if($appsecret){
            $this->appsecret = $appsecret;
        }

        
        $this->lasttime = 1395049256;
        $this->access_token = "nRZvVpDU7LxcSi7GnG2LrUcmKbAECzRf0NyDBwKlng4nMPf88d34pkzdNcvhqm4clidLGAS18cN1RTSK60p49zIZY4aO13sF-eqsCs0xjlbad-lKVskk8T7gALQ5dIrgXbQQ_TAesSasjJ210vIqTQ";

        if (time() > ($this->lasttime + 7200)){
            $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret;
            $res = $this->https_request($url);
            $result = json_decode($res, true);
            
            $this->access_token = $result["access_token"];
            $this->lasttime = time();
        }
    }//獲取使用者基本資訊
    public function get_user_info($openid)
    {
        $url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=".$this->access_token."&openid=".$openid."&lang=zh_CN";
        $res = $this->https_request($url);
        return json_decode($res, true);
    }

//https請求
    public function https_request($url, $data = null)
    {
        $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;
    }
}