婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證

詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證

熱門標(biāo)簽:桂陽公司如何做地圖標(biāo)注 太原400電話申請流程 合肥企業(yè)外呼系統(tǒng)線路 神龍斗士電話機(jī)器人 企業(yè)400電話辦理多少費(fèi)用 代理打電話機(jī)器人 宿州正規(guī)外呼系統(tǒng)軟件 電信外呼系統(tǒng)多少錢一個(gè)月 萍鄉(xiāng)商鋪地圖標(biāo)注

很多企業(yè)做項(xiàng)目使用前后端分離,后端提供接口地址,前端使用接口地址拿數(shù)據(jù),并渲染頁面。那么,前端用戶登錄如何使用接口進(jìn)行認(rèn)證?網(wǎng)上各種教程寫的不堪入目,完全看不懂,所以我根據(jù)自己的理解,寫下此篇文章,希望能幫助到大家。

后端(Laravel5.6框架)

1、使用 composer 安裝 Passport ,打開終端,執(zhí)行命令:

composer require laravel/passport  
#安裝完成后,在composer.json文件中會看到文件版本信息

2、接下來,將 Passport 的服務(wù)提供者注冊到配置文件 config/app.phpproviders 數(shù)組中

Laravel\Passport\PassportServiceProvider::class,

3、執(zhí)行數(shù)據(jù)庫遷移

php artisan migrate #數(shù)據(jù)庫中會生成接口認(rèn)證所需的5張表

4、創(chuàng)建密碼授權(quán)客戶端

php artisan passport:client --password
#創(chuàng)建了client_id和client_secret,前端登錄驗(yàn)證的時(shí)候必須把這兩個(gè)玩意兒帶著

5、獲取keys

php artisan passport:keys

6、配置路由

打開服務(wù)提供者 AuthServiceProvider , 在 boot 方法中加入如下代碼:

use Laravel\Passport\Passport;
public function boot() { 
  $this->registerPolicies(); 
  Passport::routes(); //接口認(rèn)證的路由
}

然后將配置文件 config/auth.php 中授權(quán)看守器 guardsapidriver 選項(xiàng)改為 passport

我這里的 customer 表是前端用戶表,但是 laravel 默認(rèn)的是 user 表,所以這里需要做如下配置:

'guards' => [
  'web' => [
    'driver' => 'session',
    'provider' => 'users',
  ],

  'api' => [
    'driver' => 'passport',
    'provider' => 'customers',
  ],
],
'providers' => [
  'users' => [
    'driver' => 'eloquent',
    'model' => App\User::class,
  ],
  'customers' => [
    'driver' => 'eloquent',
    'model' => App\Models\Shop\Customer::class,
  ],
],

7、注冊中間件,在 app/Http/Kernel.php 文件中的 $routeMiddleware 數(shù)組中添加如下中間件

protected $routeMiddleware = [
'client.credentials'=>\Laravel\Passport\Http\Middleware\CheckClientCredentials::class,
];

然后在需要認(rèn)證接口路由文件 routes/api.php 前面加上這個(gè)中間件。

Route::group(['prefix' => 'cart', 'middleware' => ['client.credentials']], function () {
  ...
});

8、前端用戶表 customer 模型里面做如下配置:

use Illuminate\Foundation\Auth\User as Authenticatable;
use Laravel\Passport\HasApiTokens;

class Customer extends Authenticatable
{
  use HasApiTokens;
   ....  
}

至此,后端的所有配置已完成。

接下來,打開接口測試工具(postman),輸入接口地址: wechat.test/oauth/token ,請求類型 POST ,填上如下參數(shù),點(diǎn)擊 send 你會看到后臺返回了前端所需的 access_token

 

前端(vue.js)

首先去加載用戶登錄組件,即用戶登錄頁面。

1. 配置路由,在 index.js 文件中寫入如下代碼

import Login from '@/components/customer/Login'
export default new Router({
 routes: [
    ....
  {
   path: '/customer/login',
   name: 'Login',
   component: Login
  },
 ]
})

2、加載組件,在 customer 文件夾的 Login.vue 文件中寫入如下代碼:

template>
 div>
  input type="email" v-model="customer.email" placeholder="請輸入郵箱">
  input type="password" v-model="customer.password" placeholder="請輸入密碼">
  button @click.prevent="submit">登 錄/button>
 /div>
/template>

script>
 export default {
  data() {
   return {
    customer: {
     email: '',
     password: ''
    }
   }
  },
  methods: {
   submit() {
    //將數(shù)據(jù)配置好
    const data = {
     grant_type: 'password', //oauth的模式
     client_id: 1,  //上面所說的client_id
     client_secret: 'CO331cA1mqiKgGvvgiDzPxh4CUu19vSEiqxM7LHD',//同上
     username: this.customer.email,
     password: this.customer.password,
    }
    this.axios.post('/oauth/token', data)
     .then(res => {
      if (res.status == 200) { //如果成功了,就把a(bǔ)ccess_token存入localStorage
       localStorage.token_type = res.data.token_type
       localStorage.access_token = res.data.access_token
       this.$router.push({name:'Index'})
      }
     })
   }
  }
 }
/script>

客戶端查看 localStorage ,如圖:

3、在 http.js 文件中設(shè)置攔截器,用于判斷用戶是否登錄,若沒有登錄跳轉(zhuǎn)到登錄頁面。代碼如下:

//#創(chuàng)建http.js文件
import axios from 'axios'
import router from '@/router'

// axios 配置
axios.defaults.timeout = 5000;
axios.defaults.baseURL = 'http://wechat.test/';


// http request 攔截器
axios.interceptors.request.use(
 config => { //將所有的axios的header里加上token_type和access_token
  config.headers.Authorization = `${localStorage.token_type} ${localStorage.access_token}`;
  return config;
 },
 err => {
  return Promise.reject(err);
 });

// http response 攔截器
axios.interceptors.response.use(
 response => {
  return response;
 },
 error => {
  // 401 清除token信息并跳轉(zhuǎn)到登錄頁面
  if (error.response.status == 401) {
   alert('您還沒有登錄,請先登錄')
   router.replace({  //如果失敗,跳轉(zhuǎn)到登錄頁面
    name: 'Login'
   })
  }
  return Promise.reject(error.response.data)
 });

export default axios;

重新訪問項(xiàng)目,在商品詳情頁面點(diǎn)擊加入購物車,你會發(fā)覺奇跡已經(jīng)出現(xiàn),當(dāng)你沒有登錄時(shí),提示跳轉(zhuǎn)到登錄頁面。輸入賬號密碼,登錄成功,此時(shí)就能拿到用戶id。接下來,繼續(xù)測試。

4、去 Cart 控制器中,找到購物車首頁方法,獲取用戶的id,獲取方式如下:

$customer_id = auth('api')->user()->id;
return $customer_id;

5、在 postman 中輸入購物車首頁接口地址,并傳入所需參數(shù),參數(shù)參考地址: http://laravelacademy.org/post/8909.html ,如圖:

拿到用戶id后,把后端之前定義的customer_id全部改為通過接口方法獲取。至此, Passport 接口認(rèn)證的全部操作已完成。

總結(jié):接口認(rèn)證邏輯思想

1、安裝passport后,生成client_id和 client_secret

2、使用username、password、client_id、client_secret、grant_type參數(shù),調(diào)用/oauth/token接口,拿到access_token

3、需要認(rèn)證的接口,加上中間件。這時(shí)候直接訪問接口地址,會提示沒有認(rèn)證的。帶上access_token后,才能拿到接口的數(shù)據(jù)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • laravel框架 api自定義全局異常處理方法
  • 基于laravel制作APP接口(API)
  • 基于Laravel Auth自定義接口API用戶認(rèn)證的實(shí)現(xiàn)方法
  • 詳解laravel安裝使用Passport(Api認(rèn)證)
  • laravel dingo API返回自定義錯(cuò)誤信息的實(shí)例
  • 在 Laravel 中動態(tài)隱藏 API 字段的方法
  • Laravel如何實(shí)現(xiàn)適合Api的異常處理響應(yīng)格式

標(biāo)簽:綏化 白銀 辛集 鄂州 太原 崇左 廊坊 衡陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證》,本文關(guān)鍵詞  詳解,Laravel5.6,Passport,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲色图欧洲色图| 精品一区二区三区蜜桃| 欧美日韩免费视频| 欧美一区二区三区公司| 久久―日本道色综合久久| 日韩伦理av电影| 蜜臀a∨国产成人精品| 欧美在线免费观看亚洲| 精品国内二区三区| 亚洲免费看黄网站| 国产精品一区二区果冻传媒| 欧美四级电影在线观看| 国产亚洲欧美一区在线观看| 一区二区三区.www| 亚洲色图欧美在线| 色一情一伦一子一伦一区| 精品一区二区三区久久| 亚洲图片欧美激情| 欧美日韩国产综合一区二区| 五月激情综合色| 精品国产污污免费网站入口| 97精品国产露脸对白| 4438x成人网最大色成网站| 亚洲一区二区三区小说| 久久超碰97中文字幕| 精品国产乱码久久久久久图片 | 欧美精品高清视频| 亚洲日本一区二区| 欧美久久一二三四区| 午夜精品福利在线| 国产·精品毛片| 欧美视频一区二| 日韩午夜激情免费电影| 一区二区三区精品| 99久久免费视频.com| 国产成人午夜99999| 狠狠色丁香婷婷综合| 一区二区三区在线影院| 不卡一区二区在线| 国产毛片精品视频| 老司机午夜精品| 日韩av一级片| 悠悠色在线精品| 精品精品国产高清一毛片一天堂| 欧美日韩在线不卡| 成人av综合在线| 日韩欧美一级精品久久| 日韩免费视频一区| 欧美日韩不卡一区| 亚洲成精国产精品女| 国产一区二区三区精品视频| 制服丝袜亚洲精品中文字幕| 午夜精品久久久久影视| 国产精品69久久久久水密桃 | 成人亚洲一区二区一| 欧美一区二区三区四区久久| 五月天中文字幕一区二区| 欧美日韩国产天堂| 椎名由奈av一区二区三区| 国产精品羞羞答答xxdd| 在线观看91av| 久久国产精品第一页| 久久一区二区三区四区| 久久99精品久久久久久| 国产欧美日韩久久| 成人高清免费观看| 欧美精品一二三| 欧美视频在线播放| 久久福利视频一区二区| 欧美一区二区精品久久911| 午夜av一区二区| 欧美成人乱码一区二区三区| 17c精品麻豆一区二区免费| 粉嫩绯色av一区二区在线观看| 欧美女孩性生活视频| 亚洲欧美国产高清| 老司机一区二区| 国产精品大尺度| 国产一区二区三区四区五区入口| caoporn国产精品| 日韩二区在线观看| 国产欧美一区二区在线| av电影在线不卡| 最近日韩中文字幕| 欧美一区二区三区小说| 免费成人在线网站| 久久久久久97三级| 一区二区三区国产精品| 欧美日韩另类国产亚洲欧美一级| 久久久久久亚洲综合| 亚洲视频网在线直播| 7777女厕盗摄久久久| 久久精品人人爽人人爽| 成人黄色777网| 555夜色666亚洲国产免| 亚洲精品网站在线观看| 欧美午夜精品一区| 日本麻豆一区二区三区视频| 中文字幕国产一区二区| 日韩欧美一区二区免费| 精品视频在线免费看| yourporn久久国产精品| 欧美色综合网站| 欧美性xxxxxxxx| 色吧成人激情小说| 色婷婷激情久久| 国产欧美日韩视频在线观看| 高清国产一区二区| 免费高清不卡av| 日韩免费观看高清完整版在线观看| 久久精品国产亚洲高清剧情介绍| 欧美韩国日本一区| 国产一区在线视频| 国产精品国产三级国产| 欧美丰满嫩嫩电影| 国产精选一区二区三区| 99re视频精品| 国产精品久久免费看| 欧美三级日韩三级| 成人激情av网| av日韩在线网站| 美国毛片一区二区| 亚洲国产成人私人影院tom| 欧美日本在线观看| 久久9热精品视频| 国产精品三级在线观看| 99精品国产视频| 99精品视频在线观看| 国产成人综合网| 开心九九激情九九欧美日韩精美视频电影| 国产精品免费久久久久| 亚洲欧洲日产国码二区| 精品久久久久久久久久久久包黑料| 日韩欧美国产午夜精品| 欧美日韩亚洲另类| 欧美日韩日日摸| 色婷婷综合久色| 91影视在线播放| 国产精品久久久爽爽爽麻豆色哟哟 | 成人黄色综合网站| 波多野洁衣一区| 欧美电影免费观看完整版| 精品国产凹凸成av人导航| 国内外精品视频| 久久女同性恋中文字幕| 日韩高清不卡一区二区三区| 日本亚洲视频在线| 亚洲一区二区三区影院| 日日摸夜夜添夜夜添国产精品 | 日韩精品一区二区三区视频 | 97精品久久久午夜一区二区三区 | 亚洲成人手机在线| 欧美视频一区在线| 欧美午夜在线观看| 久久久美女毛片| 综合久久国产九一剧情麻豆| 精品免费99久久| 亚洲福利视频一区| 91免费国产在线| 国产精品系列在线| 成人午夜av影视| 一区二区日韩电影| 欧美久久一二三四区| 亚洲欧美自拍偷拍| 久久成人综合网| 色久优优欧美色久优优| 亚洲三级理论片| 色婷婷综合久色| 久久精品一区二区三区不卡| 亚洲午夜久久久久| 国产麻豆视频一区二区| www.欧美色图| 韩国av一区二区三区在线观看| 欧美一区二区三区在线观看| 亚洲色欲色欲www在线观看| 国内外精品视频| 亚洲电影激情视频网站| 91浏览器入口在线观看| 久久久精品蜜桃| 国产激情精品久久久第一区二区| 97国产一区二区| 国产精品99久久不卡二区| 日本高清视频一区二区| 日日夜夜精品视频免费| 久久久一区二区三区| 在线观看视频欧美| 国产精品影视网| 全国精品久久少妇| 亚洲精选视频在线| 久久综合久久鬼色| 91色porny蝌蚪| 亚洲色图20p| 色视频成人在线观看免| 亚洲香蕉伊在人在线观| 欧美日韩中文字幕精品| 全国精品久久少妇| 欧美国产精品劲爆| 在线亚洲+欧美+日本专区| 亚洲一二三级电影| 国产精品每日更新|