ホームページ > ウェブフロントエンド > Vue.js > vuejs でインターセプトをリクエストする方法

vuejs でインターセプトをリクエストする方法

藏色散人
リリース: 2023-01-13 00:45:34
オリジナル
3259 人が閲覧しました

Vuejs リクエストインターセプト方法: 1. src フォルダーの下に utils フォルダーを作成します; 2. フォルダーの下に request.js および auth.js ファイルを作成します; 3. axios をダウンロードします; 4. インスタンス実装を作成します傍受。

vuejs でインターセプトをリクエストする方法

この記事の動作環境: Windows 7 システム、Vue バージョン 2.9.6、DELL G3 コンピューター。

vuejs リクエスト インターセプトはどのように行われますか?

vue データ リクエスト インターセプトの特定のコード

次の場所に utils ファイルを作成します。 src フォルダー フォルダー

#同時に、フォルダー下に request.js と auth.js ファイルを作成します。

request.js がリクエストのメインの入り口ですインターセプトとリクエスト データのカプセル化
auth.js は、トークンの設定、トークンの削除、ユーザーがログインしているかどうかの判断のためのメイン エントランスをカプセル化します。

auth.js (トークンのカプセル化)

export function isLogin() {
  if (localStorage.getItem('token')) {
   return true;
  } else {
   return false;
  }
 }
 export function getToken() {
  return localStorage.getItem('token');
 }
 export function setToken(token) {
  localStorage.setItem('token', token);
 }
 
 export function removeToken() {
  localStorage.removeItem('token');
 }
ログイン後にコピー

axios(コマンド: npm install axios --save-dev) をダウンロードし、axios と getToken を導入します

import axios from 'axios';
import { getToken } from './auth';
ログイン後にコピー

インスタンスを作成します: 2 つのパラメーター (timeout (タイムアウト時間)、baseUrl) を渡します(サーバー パス))

const instance = axios.create({
   timeout: 5000,
   baseURL: 'https://xxxxxxxxx/xxxx/',
 });
ログイン後にコピー

リクエスト インターセプト

// 请求拦截
 instance.interceptors.request.use(
  function(config) {
   // eslint-disable-next-line prettier/prettier
   config.headers.authorization = 'Bearer ' + getToken();
   return config;
  },
  function(error) {
   // Do something with request error
   return Promise.reject(error);
  }
 );
 
 instance.interceptors.response.use(
  response => {
   return response;
  },
  error => {
   if (error.response.status == 401) {
    window.location.href = '/#/login';
   }
   if (error.response.status == 404) {
    window.location.href = '/404.html';
   }
   return Promise.reject(error.response.data);
  }
 );
ログイン後にコピー

リクエストのカプセル化

 /**
  * 获取数据 get请求
  * @param {*} url
  * @param {*} config
  */
 export const get = (url, config) => instance.get(url, config);
 
 /**
  * post请求
  * @param {*} url
  * @param {*} data
  * @param {*} config
  */
 export const post = (url, data) => instance.post(url, data);
 /**
  * put
  * @param {*} url
  * @param {*} data
  * @param {*} config
  */
 export const put = (url, data, config) => instance.put(url, data, config);
 
 /**
  * delete
  * @param {*} url
  * @param {*} config
  */
 export const remove = (url, config) => instance.delete(url, config);
ログイン後にコピー

推奨学習: 「vue チュートリアル

以上がvuejs でインターセプトをリクエストする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
vue
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート