使用LaravelPassport的注意事項-創(chuàng)新互聯(lián)

小編給大家分享一下使用Laravel Passport的注意事項,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

青島ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

下面由Laravel教程欄目給大家分享Laravel Passport 踩坑日記,希望對需要的朋友有所幫助!

使用Laravel Passport的注意事項

以前的項目大多使用 DingoAPI + JWT-auth 實現(xiàn)的 API 認證,Laravel 雖然在很早就出了 Passport ,但一直沒有怎么關(guān)注。
今天擼了一把 Passport ,雖然遇到不少坑,但是趕腳這個東西還是蠻好用的~

坑1:我暫時只想通過賬號密碼獲取token

Passport 一出生就自帶了很多的路由。。 but,這些東東大部分對我是真的沒用啊
解決方案:
在你的AuthServiceProvider  里重新定義:

Passport::routes(function (RouteRegistrar $router) {
            $router->forAccessTokens();
        }, ['prefix' => 'api']);
坑2: 注冊賬號時,如何手動生成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"
}

完美解決。

坑3:我想要使用手機號登錄

Passport 其實已經(jīng)提供了動態(tài)修改用戶登錄的接口,只不過沒有在文檔里寫出來
解決方案:
在你的 User Model 里增加如下方法

public function findForPassport($login) {
        return User::orWhere('email', $login)->orWhere('mobile', $login)->first();
    }
坑4: 當使用錯誤的token 時, passport 總會跳轉(zhuǎn)到 login 方法

查看源碼發(fā)現(xiàn) passport 用的是webauth 中間件,難怪如此
在你的請求頭里增加Accept:application/json ,問題解決
例如:
使用Laravel Passport的注意事項

以上是“使用Laravel Passport的注意事項”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當前題目:使用LaravelPassport的注意事項-創(chuàng)新互聯(lián)
轉(zhuǎn)載來于:http://muchs.cn/article36/ddospg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)域名注冊、品牌網(wǎng)站建設(shè)、商城網(wǎng)站、定制開發(fā)、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名