Laravel6實現第三方 微信登陸

目前不少的網站中都會存在不少的交互功能,從而下降用戶的操做難度,特此帶來微信的第三方登陸的項目實戰功能開發。對於本實例中的開發內容,就不在使用原生的內容,而是直接使用別人寫好的封裝的類庫。php

1. 安裝 laravel/socialite

composer require laravel/socialite

2). 在你的 config/app.php 文件中添加如下配置信息laravel

'providers' => [
  
    Laravel\Socialite\SocialiteServiceProvider::class,
],

'aliases' => [
    'Socialite' => Laravel\Socialite\Facades\Socialite::class,
],

2. 安裝 socialiteProviders/weixin

1). 直接運行如下命令安裝擴展包微信

composer require socialiteproviders/weixin

2). 在你的 config/app.php 文件中添加如下配置信息app

'providers' => [

     \SocialiteProviders\Manager\ServiceProvider::class,
],

3). 在你的 app/Providers/EventServiceProvider.php 文件中添加如下事件處理器composer

protected $listen = [
    \SocialiteProviders\Manager\SocialiteWasCalled::class => [
        'SocialiteProviders\Weixin\WeixinExtendSocialite@handle',
    ],
];

3. 添加配置

1). 在你的 .env 文件中添加如下配置dom

WEIXIN_KEY=你的AppID
WEIXIN_SECRET=你的AppSecret
WEIXIN_REDIRECT_URI=你的回調地址

2). 在你的 config/services.php 文件中添加如下配置ide

'weixin' => [
   'client_id'     => env('WEIXIN_KEY'),
   'client_secret' => env('WEIXIN_SECRET'),
   'redirect'      => env('WEIXIN_REDIRECT_URI'),

   # 這一行配置很是重要,必需要寫成這個地址。
   'auth_base_uri' => 'https://open.weixin.qq.com/connect/qrconnect',
],

代碼調用

準備工做都完成之後,如今就到了接口對接階段。 網站

//微信一鍵登陸
Route::get('/weixin', 'WeixinController@weixin')->name('weixin');
Route::get('/weixin/callback', 'WeixinController@weixinlogin');

2). 在你的 app/Http/Controllers/WeixinController.php 文件裏添加如下方法ui

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use Laravel\Socialite\Facades\Socialite;
use App\User;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Str;

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

    public function weixinlogin(){
        $user = Socialite::driver('weixin')->user();
//        dd($user);
        $check = User::where('uid', $user->id)->where('provider', 'qq_connect')->first();
        if (!$check) {
            $customer = User::create([
                'uid' => $user->id,
                'provider' => 'qq_connect',
                'name' => $user->nickname,
                'email' => 'qq_connect+' . $user->id . '@example.com',
                'password' => bcrypt(Str::random(60)),
                'avatar' => $user->avatar
            ]);
        } else {
            $customer = $check;
        }

        Auth::login($customer, true);
        return redirect('/');
    }
}

最後就是回調後打印 oauthUser 的結果  spa

 

 

 若是有想過操做問題,想交流工做問題以及代碼能夠加入:647617935

相關文章
相關標籤/搜索