濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求

Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求

熱門標(biāo)簽:太原極信防封電銷卡 熱線電話機(jī)器人 南寧crm外呼系統(tǒng)平臺(tái) 福泉電話機(jī)器人 天津營(yíng)銷電話機(jī)器人加盟代理 電銷招聘機(jī)器人 地圖標(biāo)注入哪個(gè)科目 格陵蘭島地圖標(biāo)注 事業(yè)單位如何百度地圖標(biāo)注

1.打開(kāi) database/migrations/2014_10_12_000000_create_users_table.php 這個(gè) migration 文件, 我們需要更改 user 表的結(jié)構(gòu)

2.我們需要為 user 表添加 api_token 字段, 也就是說(shuō)我們的 token 是保存在數(shù)據(jù)庫(kù)中的, 在合適的位置, 添加一行

$table->string('api_token', 60)->unique();

3.配置好數(shù)據(jù)庫(kù), 通過(guò) php artisan migrate 命令生成 user 表

4.在user表中, 隨便添加一條記錄, 只要保證 api_token 這個(gè)字段設(shè)置為 123456 即可. 這樣我們就生成了一個(gè)用戶, 等下就可以 使用 123456 這個(gè)token 值來(lái)登錄了.

5.返回到 路由文件 routes.php, 在里面添加一條測(cè)試路由, 并將其 用 laravel 的中間件保護(hù)起來(lái)

Route::group(['middleware' => ['auth.api']], function () { 
 Route::get('/t', function () {
  return 'ok';
 });
});

在此處, 使用的是 auth.api 中間件,中間件定義入下圖:

在Middleware文件創(chuàng)建WebToken.php,然后在Kernel.php文件中注冊(cè)該中間件

'auth.api' => \App\Http\Middleware\webToken::class,

6.打開(kāi)剛剛創(chuàng)建的webToken中間件代碼如下

?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Support\Facades\Auth;

class webToken
{
 /**
  * Handle an incoming request.
  *
  * @param \Illuminate\Http\Request $request
  * @param \Closure $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
  if (Auth::guard('api')->guest()) {
   return response()->json(['code' => 401,'msg' => '未設(shè)置token']);
  }

  return $next($request);
 }
}

代碼中的Auth::guard(‘a(chǎn)pi')的api是config文件夾里auth.php文件

7.做了以上修改之后, 當(dāng)我們以 /t 這個(gè) url 路徑向服務(wù)器直接發(fā)起請(qǐng)求時(shí), 服務(wù)器就會(huì)返回一個(gè) 401 錯(cuò)誤, 并且會(huì)返回一條 ‘未設(shè)置token' 這樣的消息, 這也是我們之前在 handle() 方法中設(shè)置的. 也就是說(shuō) /t 已經(jīng)被我們的 auth 中間件保護(hù)起來(lái)了. 如果想要我們的請(qǐng)求能夠正常通過(guò)這個(gè)中間件, 就要提供 token.

8.由于我們之前在 user 表中添加了一條 api_token 為 123456 的數(shù)據(jù), 所以現(xiàn)在我們?cè)俅蜗蚍?wù)器請(qǐng)求 /t, 但是這次我們加入 api_token, 也就是

…/t?api_token=123456

正常情況下, 服務(wù)器就會(huì)返回 ‘ok' 了, 這也就是說(shuō)明, auth 中間件允許這個(gè)請(qǐng)求通過(guò). 而當(dāng)我們把 123456 修改為其他值時(shí), 這個(gè)請(qǐng)求也是無(wú)法通過(guò) auth 中間件的.

以上這篇解決laravel中api驗(yàn)證jwt刷新token的一個(gè)問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Laravel如何實(shí)現(xiàn)適合Api的異常處理響應(yīng)格式
  • Laravel5.5+ 使用API Resources快速輸出自定義JSON方法詳解
  • laravel接管Dingo-api和默認(rèn)的錯(cuò)誤處理方式
  • 在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼
  • laravel框架 api自定義全局異常處理方法
  • laravel dingo API返回自定義錯(cuò)誤信息的實(shí)例
  • laravel 配置路由 api和web定義的路由的區(qū)別詳解
  • Laravel5.4簡(jiǎn)單實(shí)現(xiàn)app接口Api Token認(rèn)證方法
  • 詳解Laravel制作API接口

標(biāo)簽:自貢 通化 阿克蘇 佳木斯 郴州 金華 寶雞 香港

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求》,本文關(guān)鍵詞  Laravel,實(shí)現(xiàn),ApiToken,認(rèn)證,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    新化县| 贡嘎县| 田东县| 兴安盟| 额尔古纳市| 托里县| 报价| 阿克陶县| 天全县| 开封市| 视频| 泰兴市| 金塔县| 萍乡市| 司法| 安图县| 福清市| 昭觉县| 美姑县| 雅江县| 固原市| 太仆寺旗| 慈利县| 池州市| 报价| 会东县| 无锡市| 汾西县| 阿鲁科尔沁旗| 衡南县| 滦平县| 那曲县| 洪湖市| 武强县| 郓城县| 澎湖县| 浙江省| 古蔺县| 尖扎县| 宝应县| 华安县|