by Devin Yang

建立于: 2年前 ( 更新: 2年前 )

Laravel提供了相当多好用的Package,像Passport就是其中之一,
当网站需要自架OAuth2验证主机时,真的是省时省力。
本站为例,因为采前后台分离机制(有两个不同的Laravel项目),我都透过前台的WEB进行验证。
基本上,我还有很多其他不同的项目,也都靠Laravel提供的OAuth2就搞定跨域验证。

当我前台WEB登录的情况下,开其他的项目就能直接登录了,
例如本站的发文后台及聊天室都采自家用的OAuth2进行验证。

讲这么多,来看我最常下的命令如下,早期Laravel还提供WEB UI组件,后来好像没了,因该发觉好像不需要了吧。😅

php artisan passport:client

 Which user ID should the client be assigned to?: (这里输入使用者编号)
 > 9

 What should we name the client?: (新的项目名称,登录时会显示给使用者这名称的App需要验证,基本我都直接AutoSubmit@@)
 > 新项目

 Where should we redirect the request after authorization? [https://www.ccc.tc/auth/callback]:
 > https://应用进程.ccc.tc/auth/ccc/callback


New client created successfully.
Client ID: n <这是Client的编号>
Client secret: <密密>

看到上面最后的画面-,如果常建OAuth验证的人应该很熟悉的感觉吧,像是脸书的OAuth验证或是Google的OAuth验证。
说白了,装了Passport我们就有自己的OAuth2验证主机了,而不是去始用Facebook或Google的。
我的聊天室主机就是大混合型,支持不同的验证,登录后就能聊天。

以下分享我.env中的命名方式,您会发觉,几乎所有的env差不多如出一辙,就像新兄弟..:p
ID、SECRET及CALLBACK。

#CCC OAuth
CCC_OAUTH_SERVER=https://www.ccc.tc
CCC_CLIENT_ID=
CCC_SECRET=
CCC_CALLBACK_URL=${APP_URL}/auth/ccc/callback

#Line Notify
LINE_NOTIFY_CLIENT_ID=
LINE_NOTIFY_SECRET=
LINE_NOTIFY_CALLBACK_URL=${APP_URL}/auth/line/notify/callback

#BOT
LINE_CHANNEL_ID=
LINE_CHANNEL_SECRET=
LINE_CALLBACK_URL=${APP_URL}/auth/line/callback

FACEBOOK_CLIENT_ID=
FACEBOOK_SECRET=
FACEBOOK_CALLBACK_URL=${APP_URL}/auth/facebook/callback

GITHUB_CLIENT_ID=
GITHUB_SECRET=
GITHUB_CALLBACK_URL=${APP_URL}/auth/github/callback

GOOGLE_CLIENT_ID=
GOOGLE_SECRET=
GOOGLE_CALLBACK_URL=${APP_URL}/auth/google/callback


如果您也尝试装Laravel的passport,目前新版的Laravel安装默认会使用sanctum,记得调回api。

Route::middleware('auth:sanctum')->get('/user', function (Request $request) {
    return $request->user();
});


关於Laravel Passport详细安装及设置,还是请看官网的说明书吧:
https://laravel.com/docs/9.x/passport

 

Tags: laravel oauth2

Devin Yang

文章内容无法一一说明,如果您有什么不了解处,欢印提问哦:)

No Comment

Post your comment

需要登入才可留言!

类似文章


Laravel, Packages,

什么样的包你必定装在所有你创建的Laravel应用进程上呢?

有什么样的包,你肯定会装在你的Laravel应用进程上呢? 这里有四星的包,几乎大家都会装, 点进来看看,我怎么说,我的实际使用使用心得分享...

laravel,letsencrypt,haproxy

PHPENV的HAProxy环境设置与免费SSL证书申请

PHPENV已经添加了haproxy.yml的支持了罗,如果您有外网IP及域名,想弄HAProxy及证书申请透过deviny/phpenv 应该相当简单。本文就让我们看看如何在PHPENV中的HAProxy环境中设置中使用HAProxy吧。

laravel,dotenv,seo

我如何依子域名动态加载Laravel不同的dotenv档

开始前先来抱怨一下,本来我的网站可以依使用者的浏览器自动显示不同的语系的。这有何不可,但Google的SEO似乎不喜欢这么搞,他建议每种语言使用不同的网址,不要用cookie或浏览器设置来调整网页内容,好吧那我只能乖乖就范了。他的建议作法,第一种方案:依国家区分,像是example.tw或example.de这真的天方夜谭怎么可能,要嘛收购被注册的域名,要不然取个全球没人会取的怪域名还比较有机会。第二种方案:用子域名区分,这正式我准备要做的,等等来说明在Laravel中怎么弄。第三种方案:example.com/tw/ 之类的,Apple好像就这么弄的。第四种方案:site.com?loc=tw之类,不建议使用,确实我也觉的这个不是一个好主意。