Laravel5.4簡單實現(xiàn)app接口Api Token認(rèn)證方法
我是小白,今天寫這篇文章主要是給新手學(xué)習(xí)看的,大佬就不用看了,有很多不足望大家指出,共同進步。
在開發(fā)中許多 API 通常在返回響應(yīng)之前都需要某種形式的認(rèn)證,有些時候,一個認(rèn)證的請求和一個未認(rèn)證的請求,響應(yīng)可能不同。
在web項目中,實現(xiàn)認(rèn)證比較輕松,那么前后端分離的項目中,我們要怎么實現(xiàn)認(rèn)證,今天這篇文章就以 API token 認(rèn)證機制,使用Token可以解決laravel API的無狀態(tài)認(rèn)證。
一、給用戶表users增加api_token字段
php artisan make:migration add_api_token_to_users
首先,給用戶表中增加 api_token字段,在生成的遷移文件中添加字段:
<?php use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class AddApiTokenToUsers extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::table('users', function (Blueprint $table) { $table->string('api_token', 64)->unique(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::table('users', function (Blueprint $table) { $table->dropColumn(['api_token']); //新增加的 }); } }
二、然后使用下面的命令將字段添加到表中:
php artisan migrate
三、用戶注冊:
在注冊的控制器文件的創(chuàng)建用戶中添加 api_token
字段:
我這里的控制器是App\Http\Controllers\Api\R
egisterController.php
protected function register(Request $request) { $input = $request->all(); //獲取傳過來的傳數(shù) //在這里設(shè)置生成token后,與賬號密碼等信息一起存進User表 $user = User::create($data); //存進數(shù)據(jù)庫 return $token; //這里面的邏輯自己寫 我這里只是簡單實現(xiàn) }
最后,不要忘記在 App\User.php
用戶模型表中的 $fillable
屬性當(dāng)中添加api_token
字段:
/** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'name', 'email', 'password','confirmation_token','api_token' ];
四、修改api driver:
接下來要在config\auth.php 修改如下內(nèi)容:
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ], 'api' => [ 'driver' => 'token', //把driver設(shè)置為token 'provider' => 'users', ], ],
五、如何使用:
接下來,我們要添加路由,在routes\api.php文件修改:
Route::group(['middleware' => 'token'], function(){ Route::post('register', 'API\UserController@register'); });
怎么訪問?我們這里用postman來測試:
到些就大功告成了! 注意,這個只是基礎(chǔ)認(rèn)證,現(xiàn)在開發(fā)還是用別人已經(jīng)開發(fā)好的插件好,比如oAuth2,basic,jwt,Passport等等。
哦對了,如果想看token的認(rèn)證原理,我們可以看他的底層源碼
vendor\laravel\framework\src\Illuminate\Auth\TokenGuard.php:
這個我也看不明白,哈!再見!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
laravel利用中間件做防非法登錄和權(quán)限控制示例
今天小編就為大家分享一篇laravel利用中間件做防非法登錄和權(quán)限控制示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP使用DOMDocument類生成HTML實例(包含常見標(biāo)簽元素)
這篇文章主要介紹了PHP使用DOMDocument類生成HTML實例,包含常見標(biāo)簽元素,如表單、表格、CSS樣式等,最后寫了一個比較完整的例子,給需要的朋友參考下2014-06-06PHP輸出當(dāng)前進程所有變量/常量/模塊/函數(shù)/類的示例
PHP輸出當(dāng)前進程所有變量、常量、模塊、函數(shù)、類的示例2013-11-11基于jQueryUI和Corethink實現(xiàn)百度的搜索提示功能
這篇文章主要介紹了基于jQueryUI和Corethink實現(xiàn)百度的搜索提示功能,這里是以corethink模塊的形式,只需要安裝上訪問index.php?s=/test/index 就可以了,需要的朋友可以參考下2016-11-11Codeigniter檢測表單post數(shù)據(jù)的方法
這篇文章主要介紹了Codeigniter檢測表單post數(shù)據(jù)的方法,實例分析了Codeigniter獲取及檢測post數(shù)據(jù)的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03