91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Laravel5.6 中使用Passport實現Api接口認證

發布時間:2021-05-27 16:38:23 來源:億速云 閱讀:207 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關怎么在Laravel5.6 中使用Passport實現Api接口認證,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

后端(Laravel5.6框架)

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

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

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

Laravel\Passport\PassportServiceProvider::class,

3、執行數據庫遷移

php artisan migrate #數據庫中會生成接口認證所需的5張表

4、創建密碼授權客戶端

php artisan passport:client --password
#創建了client_id和client_secret,前端登錄驗證的時候必須把這兩個玩意兒帶著

5、獲取keys

php artisan passport:keys

6、配置路由

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

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

然后將配置文件 config/auth.php 中授權看守器 guardsapidriver 選項改為 passport

我這里的 customer 表是前端用戶表,但是 laravel 默認的是 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 數組中添加如下中間件

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

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

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 ,填上如下參數,點擊 send 你會看到后臺返回了前端所需的 access_token

怎么在Laravel5.6 中使用Passport實現Api接口認證 

前端(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() {
    //將數據配置好
    const data = {
     grant_type: 'password', //oauth的模式
     client_id: 1,  //上面所說的client_id
     client_secret: 'CO331cA1mqiKgGvvgiDzPxh5CUu19vSEiqxM7LHD',//同上
     username: this.customer.email,
     password: this.customer.password,
    }
    this.axios.post('/oauth/token', data)
     .then(res => {
      if (res.status == 200) { //如果成功了,就把access_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實現Api接口認證

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

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

export default axios;

重新訪問項目,在商品詳情頁面點擊加入購物車,你會發覺奇跡已經出現,當你沒有登錄時,提示跳轉到登錄頁面。輸入賬號密碼,登錄成功,此時就能拿到用戶id。接下來,繼續測試。

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

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

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

怎么在Laravel5.6 中使用Passport實現Api接口認證

怎么在Laravel5.6 中使用Passport實現Api接口認證

看完上述內容,你們對怎么在Laravel5.6 中使用Passport實現Api接口認證有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

睢宁县| 广宁县| 新安县| 绥芬河市| 遂溪县| 安福县| 华池县| 锦屏县| 京山县| 沙田区| 桐梓县| 锡林浩特市| 农安县| 雷波县| 哈巴河县| 义马市| 贡觉县| 顺平县| 炎陵县| 博罗县| 弥勒县| 汉阴县| 惠水县| 宽甸| 裕民县| 米脂县| 龙门县| 杭州市| 大连市| 禄丰县| 彭泽县| 土默特右旗| 定兴县| 仁布县| 德化县| 长治市| 八宿县| 深州市| 龙州县| 新乐市| 郯城县|