激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - PHP教程 - 詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證

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

2019-09-17 13:49chenly0911 PHP教程

這篇文章主要介紹了詳解Laravel5.6 Passport實(shí)現(xiàn)Api接口認(rèn)證,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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

后端(Laravel5.6框架)

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

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

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

Laravel\Passport\PassportServiceProvider::class,

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

php artisan migrate #數(shù)據(jù)庫(kù)中會(huì)生成接口認(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)看守器 guards 的 api 的 driver 選項(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、注冊(cè)中間件,在 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;
   ....  
}

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

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

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

前端(vue.js)

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

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="請(qǐng)輸入郵箱">
  <input type="password" v-model="customer.password" placeholder="請(qǐng)輸入密碼">
  <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,  //上面所說(shuō)的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 ,如圖:

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

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

//#創(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)到登錄頁(yè)面
  if (error.response.status == 401) {
   alert('您還沒有登錄,請(qǐng)先登錄')
   router.replace({  //如果失敗,跳轉(zhuǎn)到登錄頁(yè)面
    name: 'Login'
   })
  }
  return Promise.reject(error.response.data)
 });

export default axios;

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

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

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

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

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

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

拿到用戶id后,把后端之前定義的customer_id全部改為通過(guò)接口方法獲取。至此, 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í)候直接訪問(wèn)接口地址,會(huì)提示沒有認(rèn)證的。帶上access_token后,才能拿到接口的數(shù)據(jù)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产亚洲精品精 | 国产大片全部免费看 | 毛片网站视频 | 色视频在线播放 | 成人短视频在线观看免费 | 国产精品69久久 | 免费观看视频在线 | 成人一级视频 | 精品亚洲综合 | 国产色视频一区 | 91精品久久久久久久久网影视 | 亚洲一级成人 | 一本免费视频 | 国产手机在线视频 | 91久久91久久精品免观看 | 黄色特级片黄色特级片 | 久久久国产一区二区三区 | 中文字幕免费一区 | 亚洲一区二区网址 | 国产精品免费观看视频 | 午夜视频在线 | 中文字幕网站在线 | 国产欧美亚洲精品a | 国产一区二区三区视频免费 | av影片在线观看 | 在线 日本 制服 中文 欧美 | 成人三级在线播放 | 久久久久一区二区三区 | 精品国产91久久久久久久妲己 | 成人在线视频免费看 | vidz 98hd| 成人精品一区二区三区中文字幕 | 日本大片在线播放 | 国内精品伊人久久久久网站 | 欧美日韩高清在线观看 | 免费看h网站 | 亚洲精品 在线播放 | 日本68xxxx| 午夜视频观看 | 狠狠操天天射 | 黄色电影免费网址 |