laravel如何實現(xiàn)第三方登錄?

laravel 怎么實現(xiàn)第三方登錄?——以QQ為例

  1. 例如我們需要qq的第三方登錄支持,首先需要升級sociaite,那么我們就需要安裝一個composer包,打開laragon終端。執(zhí)行安裝命令。
    composer require socialiteproviders/qq //后面的為key可以換成weibo等
  2. 跑完命令之后我們需要加入事件監(jiān)聽器:在app/Providers/EventServiceProvide.phpprotected $listen=[];中加入:
        Registered::class => [
            SendEmailVerificationNotification::class,
        ],
        'SocialiteProviders\Manager\SocialiteWasCalled' => [
            'SocialiteProviders\QQ\QqExtendSocialite@handle',
        ],
    ];
  1. .env里面配置一下keysecret
QQ_KEY=your key
QQ_SECRET=your secret
QQ_REDIRECT_URI=http://your-callback-url,
  1. config/services.php中加入
    'client_id' => env('QQ_KEY'),         // Your QQ Client ID
    'client_secret' => env('QQ_SECRET'), // Your QQ Client Secret
    'redirect' =>env('QQ_REDIRECT_URI'),  //這個地址很重要
],
  1. 設(shè)計路由:在web.php當(dāng)中,思考:我們需要定義兩個路由,一個是跳轉(zhuǎn)到qq登錄給予權(quán)限的頁面,和qq回退過來之后的頁面,路由設(shè)計如下:
    Route::namespace('Auth')->prefix('auth/qq')->group(function () {
    Route::get('/', 'SocialitesController@qq');
    Route::get('callback', 'SocialitesController@callback');
});

前綴和命名空間可以隨意更改,打印路由終端命令:php artisan r:l

  1. login.blade.php當(dāng)中加入QQ登錄按鈕,給一個a便簽加入上面設(shè)計的路由地址:<a href="/auth/qq></a>"
  2. 新建第三方登錄管理控制器,終端命令:php artisan make:controller Auth\SocialitesController
  3. 打開控制器輸入一下代碼:
<?php

namespace App\Http\Controllers\Auth;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Socialite;
use App\User;
use Illuminate\Support\Str;

class SocialitesController extends Controller
{
    public function qq()
    {
        return Socialite::with('qq')->redirect();
    }

    //用戶授權(quán)后,跳轉(zhuǎn)回來
    public function callback()
    {
        $message= Socialite::driver('qq')->user();
        dump($message);exit;
    }
}

查看見qq返回過來的信息。
會得到如下信息。

<pre class="sf-dump" id="sf-dump-616717864" data-indent-pad="  " tabindex="0" style="display: block; white-space: pre-wrap; padding: 5px; overflow: initial !important; background-color: rgb(24, 23, 27); color: rgb(255, 132, 0); font: 400 12px Menlo, Monaco, Consolas, monospace; overflow-wrap: break-word; position: relative; z-index: 99999; word-break: break-all; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-style: initial; text-decoration-color: initial;"><abbr title="SocialiteProviders\Manager\OAuth2\User" class="sf-dump-note" style="text-decoration: none; border: none; cursor: pointer; color: rgb(18, 153, 218);">User</abbr> {#361 ▼ <samp data-depth="1" class="sf-dump-expanded">+accessTokenResponseBody: array:3 [?]
  +token: "2B2A83C5B937C1139B03BBBBB7F2DAB6"
  +refreshToken: "B553B05ECBC7981B8AE18C5E85117A68"
  +expiresIn: "7776000"
  +id: "4BB34E789377567E0323577F5233D7F2"
  +nickname: "****"
  +name: null
  +email: null
  +avatar: "http://thirdqq.qlogo.cn/g?b=oidb&k=tHUTU6J82j7LSnmjPUKUAw&s=100&t=1560692607"
  +user: array:21 [▼ <samp data-depth="2" class="sf-dump-expanded">"ret" => 0
    "msg" => ""
    "is_lost" => 0
    "nickname" => "***"
    "gender" => "***"
    "province" => "***"
    "city" => "***"
    "year" => "****"
    "constellation" => ""
    "figureurl" => "http://qzapp.qlogo.cn/qzapp/"
    "figureurl_1" => "http://qzapp.qlogo.cn/qzapp/"
    "figureurl_2" => "http://qzapp.qlogo.cn/qzapp/"
    "figureurl_qq_1" => "http://thirdqq.qlogo.cn"
    "figureurl_qq_2" => "http://thirdqq.qlogo.cn"
    "figureurl_qq" => "http://thirdqq.qlogo.cn"
    "figureurl_type" => "1"
    "is_yellow_vip" => "0"
    "vip" => "0"
    "yellow_vip_level" => "0"
    "level" => "0"
    "is_yellow_year_vip" => "0"</samp> ]
  +"unionid": ""</samp> }</pre>

這些就是QQ給你返回的用戶信息
我們需要把這些得到的信息選取有用字段插入到我們的users表中。

  1. 檢查模型白名單:
protected $fillable = ['填寫要插入的字段名'];
  1. dump屏蔽改為以下代碼
 $user = User::where('provider', 'qq')->where('uid', $info->id)->first();
        //這里是判斷user是否存在,如果存在就直接登錄了
        //不存在直接執(zhí)行插入
        if (!$user) {
        //直接插入數(shù)據(jù)庫的對應(yīng)字段,注意寫白名單
            $user = User::create([
                'username'=>$message->nickname,
                'provider' => 'qq',   //寫死了,這里隨意
                'uid' => $message->id,
                'email' => 'qq+' . $message->id . '@qq.com',    //這里拼的是個假的郵箱地址防止報錯,但要符合郵箱格式,做了驗證也需要唯一
                'password' => bcrypt(Str::random(10)),   //這里也是設(shè)置了一個假的密碼,隨機生成一個10位的密碼,防止報錯
                'name' => $message->nickname,
                'avatar' => $message->avatar,
            ]);
        }

        //Auth::login($user);
        Auth::login($user, true);
        return redirect('/admin'); //這里是個調(diào)轉(zhuǎn) 登錄完后跳轉(zhuǎn)到后臺首頁
  1. 以上搞完基本OK、
    'redirect' =>env('QQ_REDIRECT_URI'), //這個地址很重要
    這個地址需要和你申請qq互聯(lián)應(yīng)用的那個回調(diào)地址對應(yīng),并且訪問也需要與前面的地址對應(yīng),不然會報no message的錯誤
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容