解决跨域问题 Vue

  1. 在src目录下创建一个utils文件夹然后创建一个request.js 文件
import axios from 'axios'

const request = axios.create({
  baseURL: '/api', // 注意!! 这里是全局统一加上了 '/api' 前缀,也就是说所有接口都会加上'/api'前缀在,页面里面写接口的时候就不要加 '/api'了,否则会出现2个'/api',类似 '/api/api/user'这样的报错,切记!!!
  timeout: 5000
})

// request 拦截器
// 可以自请求发送前对请求做一些处理
// 比如统一加token,对请求参数统一加密
request.interceptors.request.use(config => {
  config.headers['Content-Type'] = 'application/json;charset=utf-8'

  // config.headers['token'] = user.token;  // 设置请求头
  return config
}, error => {
  return Promise.reject(error)
})

// response 拦截器
// 可以在接口响应后统一处理结果
request.interceptors.response.use(
  response => {
    let res = response.data
    // 如果是返回的文件
    if (response.config.responseType === 'blob') {
      return res
    }
    // 兼容服务端返回的字符串数据
    if (typeof res === 'string') {
      res = res ? JSON.parse(res) : res
    }
    return res
  },
  error => {
    console.log('err' + error) // for debug
    return Promise.reject(error)
  }
)

export default request
  1. 在项目的根目录下创建一个vue.config.js文件
// 跨域配置
module.exports = {
  devServer: { // 记住,别写错了devServer//设置本地默认端口  选填
    port: 9876, //vue项目启动的时候的端口号
    proxy: { // 设置代理,必须填
      '/api': { // 设置拦截器  拦截器格式   斜杠+拦截器名字,名字可以自己定
        target: 'http://localhost:9903', // 代理的目标地址
        changeOrigin: true, // 是否设置同源,输入是的
        pathRewrite: { // 路径重写
          '^/api': '' // 选择忽略拦截器里面的内容
        }
      }
    }
  }
}

posted @ 2022-03-19 14:40  Primary丶  阅读(27)  评论(0编辑  收藏  举报