摘要:本文來自原文鏈接歡迎作客我們的學習群比如說你要給你的手機用戶創建,使用的是你已有的系統里的數據庫,尤其是用戶數據。
本文來自pilishen.com----原文鏈接; 歡迎作客我們的php&Laravel學習群:109256050
比如說你要給你的手機APP用戶創建API,使用的是你已有的Laravel系統里的數據庫,尤其是用戶數據?,F在我們來看一下,這里使用的是Laravel Passport組件。
我們將要創建三個api,分別是:
Login API
Register API
Details API
(一)安裝和配置Passportcomposer require laravel/passport
在config/app.php中注冊provider:
"providers" => [ .... LaravelPassportPassportServiceProvider::class, ],
創建Passport需要的數據表:
php artisan migrate
然后初始化Passport,執行:
php artisan passport:install
該命令會生成用以后期創建安全令牌(access token)的秘鑰,同時也會創建personal access和password grant兩個客戶端(clients)。
接下來,在app/User.php中添加HasApiTokens trait:
然后在app/Providers/AuthServiceProvider.php中添加Passport::routes();:
registerPolicies(); Passport::routes(); } }在config/auth.php中將api的driver改成passport:
[ ... "api" => [ "driver" => "passport", "provider" => "users", ], ], ..... ](二)創建相應的api路由在你的routes/api.php中
Route::post("login", "APIUserController@login"); Route::post("register", "APIUserController@register"); Route::group(["middleware" => "auth:api"], function(){ Route::post("details", "APIUserController@details"); });(三)創建相應的controller路徑app/Http/Controllers/API/UserController.php
request("email"), "password" => request("password")])){ $user = Auth::user(); $success["token"] = $user->createToken("MyApp")->accessToken; return response()->json(["success" => $success], $this->successStatus); } else{ return response()->json(["error"=>"Unauthorised"], 401); } } public function register(Request $request) { $validator = Validator::make($request->all(), [ "name" => "required", "email" => "required|email", "password" => "required", "c_password" => "required|same:password", ]); if ($validator->fails()) { return response()->json(["error"=>$validator->errors()], 401); } $input = $request->all(); $input["password"] = bcrypt($input["password"]); $user = User::create($input); $success["token"] = $user->createToken("MyApp")->accessToken; $success["name"] = $user->name; return response()->json(["success"=>$success], $this->successStatus); } public function details() { $user = Auth::user(); return response()->json(["success" => $user], $this->successStatus); } }(四)使用rest client來測試apiLogin API:
Register API:
Details API:
這個測試前需要添加一些header信息:
"headers" => [ "Accept" => "application/json", "Authorization" => "Bearer ".$accessToken, ][譯文出處:
//itsolutionstuff.com/post/laravel-5-how-to-create-api-authentication-using-passport-example.html](//itsolutionstuff.com/post/laravel-5-how-to-create-api-authentication-using-passport-example.html)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/28334.html
摘要:在本教程中,我們將了解如何在應用中使用認證。當用戶通過登錄時,會生成令牌并將其發送給用戶,該用戶可用于身份驗證。提供,可以毫無困難地使用認證。服務提供者我們使用的最新版本,它可以使用包發現并自動注冊服務。 showImg(https://segmentfault.com/img/remote/1460000019095408?w=1000&h=526); 在本教程中,我們將了解如何在 ...
摘要:模糊授權,跟上面的認證碼授權類似,不同的是,我們的資源服務器,返回的直接就是準入令牌,而不是認證碼。 本文來自pilishen.com----原文鏈接; 歡迎來和pilishen一起學習php&Laravel;學習群:109256050 OAuth2是一個安全框架,控制著程序受保護部分的準入,主要是控制不同的客戶端如何來調取API,保證它們在請求相應資源的時候有相應的權限。 Larav...
摘要:第一部分安裝第一步使用安裝第二步服務提供器使用框架注冊自己的數據庫遷移目錄,因此在注冊提供器后,就應該運行的遷移命令來自動創建存儲客戶端和令牌的數據表第三步接下來,運行命令來創建生成安全訪問令牌時所需的加密密鑰,同時,這條命令也會創建用于生 第一部分 安裝Passport(laravel/passport) 第一步. 使用 Composer 安裝 Passport :composer...
摘要:使用進行測試注冊接口,注冊成功后返回與用戶名登錄接口詳情接口參考了簡書浪來了的認證應用實戰 安裝larave laravel new passport_demo cd passport_demo && composer install 將 .env 中數據庫配置修改為自己的數據庫配置 DB_DATABASE=homestead DB_USERNAME=homestead DB_P...
摘要:看到社區常有人問用于密碼驗證方式來獲取的問題,剛好我最近一個項目使用,也是使用的密碼授權來做驗證,對于如何做登錄登出,以及多賬號系統的認證等常用場景做一下簡單的使用小總結。 看到Laravel-China社區常有人問Laravel Passport用于密碼驗證方式來獲取Token的問題,剛好我最近一個API項目使用Laravel Dingo Api+Passport,也是使用Oauth...
閱讀 2146·2021-10-12 10:11
閱讀 846·2021-10-09 09:41
閱讀 3760·2021-09-09 11:37
閱讀 1940·2021-09-08 10:41
閱讀 2641·2019-08-30 12:58
閱讀 2373·2019-08-30 10:58
閱讀 1278·2019-08-26 13:40
閱讀 4113·2019-08-26 13:36