第三方登陆认证能简化用户登陆/注册的操做,下降用户登陆/注册的门槛,对提升应用的用户转化率颇有帮助。php
Laravel 为咱们提供了简单、易用的方式,使用 Laravel Socialite 进行 OAuth(OAuth1 和 OAuth2 都有支持) 认证。laravel
Socialite 目前支持的认证有 Facebook、Twitter、Google、LinkedIn、GitHub、Bitbucket。(恩,有一半是“不存在”的网站。)
Socialite 的用法官方文档中已经讲得很详细了,恕不赘述。
英文好的同窗,建议直接看 Laravel 官方文档,毕竟看二手知识是有高风险的。
英文很差的同窗(好比我),下面是中文文档:
Laravel 5.0:http://laravel-china.org/docs/5.0/authentication#social-authentication
Laravel 5.1:http://laravel.tw/docs/5.1/authentication#social-authenticationgit
SocialiteProviders 经过扩展 Socialite 的 Driver,实现了不少第三方认证。国内的有:微博、QQ、微信、豆瓣。固然你本身也能够参照实现其余的,只要那个网站支持 OAuth。
SocialiteProviders 的使用也超级简单易用,每一个都对应了文档。其实,不懂英文也能看懂。
文档地址:http://socialiteproviders.github.io/
其实,文章到这里就应该结束了。因为文档是基于 Laravel5.0 的,因此我仍是打算基于 Laravel5.1 演示一遍,并说一下要注意的地方吧。github
composer require socialiteproviders/weibo
若是以前添加过 Socialite Provider,得先注释掉:
文件 config/app.php
shell
'providers' => [ // Laravel\Socialite\SocialiteServiceProvider::class, SocialiteProviders\Manager\ServiceProvider::class, // add ],
若是以前安装 Socialite 时添加过,就不须要再添加了。
仍是文件 config/app.php
微信
'aliases' => [ 'Socialite' => Laravel\Socialite\Facades\Socialite::class, // add ],
文件 app/Providers/EventServiceProvider.php
app
protected $listen = [ 'SocialiteProviders\Manager\SocialiteWasCalled' => [ 'SocialiteProviders\Weibo\WeiboExtendSocialite@handle', ], ];
这里顺便提一下 SocialiteProviders 的原理。composer
SocialiteProviders\Manager\ServiceProvider
其实是继承于 Laravel\Socialite\SocialiteServiceProvider
的,这是它的源码:ide
<?php namespace SocialiteProviders\Manager; use Illuminate\Contracts\Events\Dispatcher; use Laravel\Socialite\SocialiteServiceProvider; class ServiceProvider extends SocialiteServiceProvider { /** * @param Dispatcher $event * @param SocialiteWasCalled $socialiteWasCalled */ public function boot(Dispatcher $event, SocialiteWasCalled $socialiteWasCalled) { $event->fire($socialiteWasCalled); } }
它只是在启动时会触发 SocialiteWasCalled
事件,刚才在 SocialiteProviders\Manager\SocialiteWasCalled
事件的监听器中加上了事件处理器:SocialiteProviders\Weibo\WeiboExtendSocialite@handle
。处理器的源码:测试
<?php namespace SocialiteProviders\Weibo; use SocialiteProviders\Manager\SocialiteWasCalled; class WeiboExtendSocialite { public function handle(SocialiteWasCalled $socialiteWasCalled) { $socialiteWasCalled->extendSocialite('weibo', __NAMESPACE__.'\Provider'); } }
处理器作的事情就是为 Socialite 添加了一个 weibo Driver,这样就可使用 weibo 的 Driver 了。
文件 app/Http/routes.php
// 引导用户到新浪微博的登陆受权页面 Route::get('auth/weibo', 'Auth\AuthController@weibo'); // 用户受权后新浪微博回调的页面 Route::get('auth/callback', 'Auth\AuthController@callback');
文件 config/services.php
'weibo' => [ 'client_id' => env('WEIBO_KEY'), 'client_secret' => env('WEIBO_SECRET'), 'redirect' => env('WEIBO_REDIRECT_URI'), ],
文件 .env
WEIBO_KEY=yourkeyfortheservice WEIBO_SECRET=yoursecretfortheservice WEIBO_REDIRECT_URI=http://192.168.1.7/laravel/public/auth/callback
注意:192.168.1.7 是我本地虚拟机的地址,虚拟机能够连外网就能够测试了。貌似 QQ 的必须绑定域名才是测试。
固然,直接将配置的具体参数写在 config/services.php
中也是能够的,可是不推荐这样。由于 config/services.php
属于代码文件,而 .env
属于配置文件。当代码上线是只要应用线上环境的配置文件便可,而不须要改动代码文件,这算是一个最佳实践吧。
至于 WEIBO_KEY
和 WEIBO_SECRET
的具体值,这个是由新浪微博分发给你的,在新浪微博的受权回调页中填写 WEIBO_REDIRECT_URI
。这些细节已经超出本文的内容,建议直接到 http://open.weibo.com 查阅新浪微博的手册。
文件 app/Http/Controllers/Auth/AuthController.php
public function weibo() { return \Socialite::with('weibo')->redirect(); // return \Socialite::with('weibo')->scopes(array('email'))->redirect(); } public function callback() { $oauthUser = \Socialite::with('weibo')->user(); var_dump($oauthUser->getId()); var_dump($oauthUser->getNickname()); var_dump($oauthUser->getName()); var_dump($oauthUser->getEmail()); var_dump($oauthUser->getAvatar()); }
访问 http://192.168.1.7/laravel/public/auth/weibo
,会跳转到新浪微博的登陆受权页面,受权成功后,会跳转到 http://192.168.1.7/laravel/public/auth/callback
返回的结果:
string(10) "3221174302" string(11) "Mr_Jing1992" NULL NULL string(50) "http://tp3.sinaimg.cn/3221174302/180/40064692810/1"
user 对象是现实了接口 Laravel\Socialite\Contracts\User
的,有如下几个方法:
<?php namespace Laravel\Socialite\Contracts; interface User { public function getId(); public function getNickname(); public function getName(); public function getEmail(); public function getAvatar(); }
固然,并非有了这些方法就必定能获取到你须要的数据的。好比,在新浪的接口中,想要获取用户的 email 是得用户受权的,获得受权后请求获取邮箱的接口,才能拿到用户的邮箱。
详情参见:
http://open.weibo.com/wiki/Scope
http://open.weibo.com/wiki/2/account/profile/email
可是,id 这个应该是全部第三方认证服务提供商都会返回的。否则那就没有办法做帐号关联了。
获取到第三方的 id 后,若是这个 id 和你网站用户帐号有绑定,就直接登陆你网站用户的帐号。若是没有任何帐号与之绑定,就应该提示用户绑定已有帐号或者是注册新帐号什么的,这些具体逻辑就不在多说了。还有,在新浪上面还有一个取消受权回调页的值须要填,是用户在受权页点击“取消”按钮时新浪回调的页面。这个能够设置为你网站的登陆页面或者其余页面。
补充:
http://socialiteproviders.github.io/providers/qq/ 文档中有一处错误。SocialiteProviders\QQ\QqExtendSocialite@handle
应该改成:SocialiteProviders\Qq\QqExtendSocialite@handle
。注意大小写。
最后:若有错误,还望指正。