axios跨域請求詳解

一、axios跨域請求cookie丟失

當使用axios發起跨域請求時,可能會遇到cookie丟失的問題。

這是因為在跨域請求時,瀏覽器默認會禁止攜帶cookie信息,防止CSRF攻擊。

解決這個問題的方法有兩種:一種是在服務端設置Access-Control-Allow-Credentials為true,表示允許跨域請求攜帶cookie;另一種是在axios請求的withCredentials設置為true,表示允許跨域請求攜帶cookie。


// 服務端代碼
app.use((req, res, next) => {
  res.header('Access-Control-Allow-Credentials', 'true');
  res.header('Access-Control-Allow-Origin', req.headers.origin);
  next();
});

// axios跨域請求
axios.get(url, {
  withCredentials: true
}).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

二、axios實現跨域請求

axios可以通過設置請求頭,實現跨域請求。

在axios請求時,可以設置請求頭中的”Access-Control-Allow-Origin”,”Access-Control-Allow-Methods”和”Access-Control-Allow-Headers”字段,讓服務端允許跨域請求。


// axios跨域請求
axios.get(url, {
  headers: {
    'Access-Control-Allow-Origin': '*',
    'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE',
    'Access-Control-Allow-Headers': 'Content-Type, Authorization'
  }
}).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

三、axios跨域請求設置

除了設置請求頭和withCredentials外,我們還可以通過配置axios的全局設置,來實現跨域請求。具體來說,我們可以通過設置axios.defaults.baseURL和axios.defaults.withCredentials來實現跨域請求。


// 設置axios的全局配置
axios.defaults.baseURL = 'http://example.com';
axios.defaults.withCredentials = true;

// axios跨域請求
axios.get(url).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

四、vue3 axios跨域請求

在vue3中,我們可以通過安裝vue-axios插件,來進行跨域請求。

首先,在vue項目中安裝vue-axios插件:


npm install axios vue-axios --save

然後,在main.js中進行配置:


import axios from 'axios';
import VueAxios from 'vue-axios';
import Vue from 'vue';

Vue.use(VueAxios, axios);

Vue.axios.defaults.baseURL = '/api';
Vue.axios.defaults.withCredentials = true;

最後,在組件中使用:


const params = {
  name: 'Alice',
  age: 18
};

this.axios.get('/user', {params}).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

五、axios請求頭允許跨域

有時候我們需要在請求頭中添加一些自定義的字段,此時需要在服務端配置Access-Control-Allow-Headers,允許跨域請求頭中包含自定義字段。


// 服務端代碼
res.header('Access-Control-Allow-Origin', '*');
res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization, Token');

// axios請求頭設置
const headers = {
  'Authorization': 'Bearer xxx',
  'Token': 'yyy'
};

axios.get(url, {headers}).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

六、axios封裝請求

為了方便調用,我們可以把常用的axios請求封裝成一個函數。


// 封裝請求函數
const request = (url, method, data) => {
  const config = {
    method,
    url,
    headers: {'Content-Type': 'application/json'},
    data
  };
  return axios(config);
};

// 使用封裝的請求函數進行請求
const params = {
  name: 'Alice',
  age: 18
};

request('/user', 'get', params).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

七、axios添加請求頭跨域

我們還可以把跨域請求需要的請求頭,封裝進axios的攔截器中,這樣可以使請求更加方便。


// 添加攔截器
axios.interceptors.request.use(config => {
  config.headers['Content-Type'] = 'application/json';
  config.headers['Authorization'] = 'Bearer xxx';
  return config;
}, error => {
  return Promise.reject(error);
});

// axios請求
axios.get(url).then(res => {
  console.log(res);
}).catch(error => {
  console.log(error);
});

八、axios解決跨域

在使用axios進行跨域請求時,可能會遇到各種各樣的問題,比如請求返回404錯誤,請求超時等等。

解決這些問題的方法有很多種,比如調整請求方式、修改請求頭、增加請求參數等等。

下面是一些常見的解決方案:

1、把跨域請求的域名加入到CORS白名單中;

2、在服務端設置Access-Control-Allow-Origin為請求域名;

3、把請求的數據類型從JSON改成字面量;

4、使用JSONP代替AJAX請求;

5、使用代理服務器,把請求轉發到目標服務器。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/283046.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 08:06
下一篇 2024-12-22 08:06

相關推薦

  • 使用axios獲取返回圖片

    使用axios獲取返回圖片是Web開發中很常見的需求。本文將介紹如何使用axios獲取返回圖片,並從多個方面進行詳細闡述。 一、安裝axios 使用axios獲取返回圖片前,首先需…

    編程 2025-04-29
  • Axios請求數據亂碼問題解決

    本文將從以下三個方面詳細闡述Axios請求數據亂碼問題的原因和解決方法: 一、設置請求頭 Axios請求數據亂碼的原因可能是因為請求時沒有設置請求頭的編碼方式,而且默認的編碼方式是…

    編程 2025-04-28
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁盤中。在執行sync之前,所有的文件系統更新將不會立即寫入磁盤,而是先緩存在內存…

    編程 2025-04-25
  • 神經網絡代碼詳解

    神經網絡作為一種人工智能技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網絡的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網絡模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變量讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web服務器。nginx是一個高性能的反向代理web服務器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性傳感器,能夠同時測量加速度和角速度。它由三個傳感器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分布式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25

發表回復

登錄後才能評論