• Laravel OAuth2 (一) 简单获取用户信息


    前言

    本来要求是使用微信进行第三方登陆,所以想着先用 github 测试成功再用微信测试,可是最近拖了好久都还没申请好微信开放平台的 AppID ,所以就只写 github 的第三方登陆吧,估计微信的实现也差不多~

    关于OAuth2

    关于OAuth2的理解,推荐大家先去看一下阮一峰的文章理解OAuth 2.0,看完这个之后相信就能对 OAuth2 有了一定的了解,因为在 Laravel 里面很多东西都已经封装好了,如果只是单纯的实现功能感觉并不能学到多少东西,Laravel 使用的授权模式是授权码模式。从 Laravel 的官方文档来看,其实几行代码就能实现第三方登陆的功能,但是不一定能满足我们的项目需求。这篇文章也简单记录了博主在学着使用 Laravel 的 Facaces 和 Service 模式。

    准备工作

    github

    首先去 github 上面注册一个 Application :

    Personal settings->Applications->Developer applications->Register new application 填写相关信息:

    然后就可以得到一个 Client ID 和 Client Secret :

    好,到此为止,github上面的准备工作就完成了。


    配置

    首先在命令行中执行以下命令安装插件:

    composer require laravel/socialite
    

    然后在config/app.php文件中注册服务提供者和添加 Socialite 的 facade :

    'providers' => [   //只有注册了的服务才能用
        // Other service providers...
    
        Laravel\Socialite\SocialiteServiceProvider::class,
    ],
    
    'aliases' => [   //个人理解Facade就是将一些类的很长的路径用一个单词表示
        // Other facades...
        'Socialite' => Laravel\Socialite\Facades\Socialite::class,
    ],
    

    然后我们就要到services.php中去配置 github 的 Client ID 和 Client Secret:

    'github' => [    //使用env配置文件就省去了部署到服务器时修改代码的麻烦
            'client_id' => env('GITHUB_KEY'),
            'client_secret' => env('GITHUB_SECRET'),
            'redirect' => env('GITHUB_REDIRECT_URI'),
        ],
    

    在.env文件中添加以下信息(就是在github上面注册的信息):

    GITHUB_KEY=02e00704589a50f7f58d
    GITHUB_SECRET=5793aefaa0ee643d8d78b3cf4dc7101a477fd406
    GITHUB_REDIRECT_URI=http://suip.app/login/github/callback
    

    上面回调的URL一定要和 github 上面填写的一样,不然 github 的服务器检查到不一样会拒绝服务。

    开始使用

    添加路由

    Route::get('login/{provider}', 'Auth\AuthController@redirectToProvider');
    Route::get('login/{provider}/callback', 'Autu\AuthController@handleProviderCallback');
    

    控制器

    Auth\AuthController控制器中实现 redirectToProvider 和 handleProviderCallback 函数:

    public function redirectToProvider()
    {
        return Socialite::driver('github')->redirect();
    }
    
    public function handleProviderCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }
    

    ok,现在访问suip.app/login/github就会重定向到 github 认证的界面:

    确认授权后就会重定向到suip.app/login/github/callback,由于在控制器中 dd 了 $user ,所以就能直接显示用户信息了。

    到此为止获取用户信息就结束了

  • 相关阅读:
    Object.keys方法
    vue数据绑定原理
    JS控制数字从指定数开始变化
    传入参数和回调取值
    Android contacts content provider学习小结
    Android输入法框架分析(1)-三大组件
    通过Android View的两种事件响应方法比较inheritance和composition
    对象间相互调用时互相控制的几种方法
    immutable和mutable对象
    关于Unicode
  • 原文地址:https://www.cnblogs.com/pengzhendong/p/4847198.html
Copyright © 2020-2023  润新知