小編給大家分享一下使用Laravel Passport的注意事項,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、微信小程序開發(fā)、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了景泰免費建站歡迎大家使用!
下面由Laravel教程欄目給大家分享Laravel Passport 踩坑日記,希望對需要的朋友有所幫助!
以前的項目大多使用 DingoAPI + JWT-auth 實現(xiàn)的 API 認證,Laravel 雖然在很早就出了 Passport ,但一直沒有怎么關(guān)注。
今天擼了一把 Passport ,雖然遇到不少坑,但是趕腳這個東西還是蠻好用的~
token
Passport 一出生就自帶了很多的路由。。 but,這些東東大部分對我是真的沒用啊
解決方案:
在你的 AuthServiceProvider
里重新定義:
Passport::routes(function (RouteRegistrar $router) { $router->forAccessTokens(); }, ['prefix' => 'api']);
Token
?jwt-auth 的 JWTAuth::fromUser($user);
可以很簡單的生成token
,但是在 Passport 里似乎沒有現(xiàn)成的方法。
解決方案:
注冊完賬號后,再一次主動請求 oauth/token
public function register(Request $request) { $validator = $this->validator($request->all()); if ($validator->fails()){ return response()->json($validator->errors()); } event(new Registered($user = $this->create($request->all()))); $client = \DB::table('oauth_clients')->where('password_client', 1)->first(); $request->request->add([ 'username' => $user->email, 'password' => $request->password, 'grant_type' => 'password', 'client_id' => $client->id, 'client_secret' => $client->secret, 'scope' => '*' ]); $proxy = Request::create( 'oauth/token', 'POST' ); return Route::dispatch($proxy); }
執(zhí)行,獲得返回
{ "token_type": "Bearer", "expires_in": 1296000, "access_token": "xxx", "refresh_token": "xxx" }
完美解決。
Passport 其實已經(jīng)提供了動態(tài)修改用戶登錄的接口,只不過沒有在文檔里寫出來
解決方案:
在你的 User Model 里增加如下方法
public function findForPassport($login) { return User::orWhere('email', $login)->orWhere('mobile', $login)->first(); }
token
時, passport 總會跳轉(zhuǎn)到 login 方法查看源碼發(fā)現(xiàn) passport 用的是 web
auth
中間件,難怪如此
在你的請求頭里增加 Accept:application/json
,問題解決
例如:
以上是“使用Laravel Passport的注意事項”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!