如何配置 vue.config.js 解决跨域?(解决生产环境中的跨域问题,举例:vue-admin-template)以及axios的配置

原理:

1、将域名发送给本地服务器(localhost:9528)

2、再由本地服务器去请求真正的服务器

3、服务端发出的请求,不存在跨域问题

请注意,我们所遇到的这种跨域是位于开发环境 (webpack代理服务器),真正部署上线时的跨域是

生产环境 (nginx服务器, 或者后台配cors)

以下是vue.config.js的详细配置:

devServer: {
   // 跨域
   proxy: {
   // 只要axios请求中带有/api的url,就会触发代理机制
   '/api': {
      // 目标路径:target(我们要代理请求的地址)
      target: 'http://xxxxxxxxxxx.xxx/api',
      // 允许跨域
      changOrigin: true,
      // 重写路径 api代替了目标路径
      pathRewrite: {
        '^/api': ''
      }
     }
   },
 },

基于vue-admin-template后台管理系统来说

数据请求方式:axios (开发环境)

第一步:在.env.development文件中设置开发环境数据请求的基础路径

#开发阶段的配置文件
#举例
#思考:开发阶段的接口 baseURL="dev.bank.com"

#npm run dev  开发阶段 自动的加载.development数据
#npm run build 产品上线 自动的加载.env.production

#在配置文件中声明的数据 环境变量

# just a flag
ENV = 'development'

# base api
# VUE_APP_BASE_API = '/dev-api'
#设置开发环境数据请求的基础路径
#我只写一个'/api',会自动匹配我的个人地址http://localhost:8888
VUE_APP_BASE_API = '/api'

第二步:在src/utils/request.js文件中设置axios路径,就是开发环境.env.development文件中的根路径

import axios from 'axios'
// create an axios instance
// const service = axios.create({
//   baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
//   // withCredentials: true, // send cookies when cross-domain requests
//   timeout: 5000 // request timeout
// })
const service = axios.create({
  // baseURL: 'http://localhost:8888/api',
  //
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000
})
//请求拦截器和响应拦截器也写在此文件夹中
export default service

第三步:api模块的单独封装:在src/api文件夹下都是所有的axios请求

//导入在src/utils/request里面设置的axios基础路径
import request from '@/utils/request'
//把axios请求封装成函数,目的:在组件中调用
export function login(data) {
  return request({
    //例如登录请求
    url: '/sys/login',
    method: 'post',
    data
  })
}
//注意:导出方式为按需导出

第四步:若是有跨域问题,需要在vue.config.js中设置跨域

=========================================================================

关于axios的配置

  • 安装 axios
npm i axios
  • 新建 src/utils/request.js 模块,代码如下
// 1. 创建一个新的axios实例
// 2. 请求拦截器,如果有token进行头部携带
// 3. 响应拦截器:1. 剥离无效数据  2. 处理token失效
// 4. 导出一个函数,调用当前的axsio实例发请求,返回值promise

import axios from 'axios'
import store from '@/store'
import router from '@/router'

// 导出基准地址,原因:其他地方不是通过axios发请求的地方用上基准地址
export const baseURL = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx/'
const instance = axios.create({
  // axios 的一些配置,baseURL  timeout
  baseURL,
  timeout: 5000
})

instance.interceptors.request.use(config => {
  // 拦截业务逻辑
  // 进行请求配置的修改
  // 如果本地又token就在头部携带
  // 1. 获取用户信息对象
  const { profile } = store.state.user
  // 2. 判断是否有token
  if (profile.token) {
    // 3. 设置token
    config.headers.Authorization = `Bearer ${profile.token}`
  }
  return config
}, err => {
  return Promise.reject(err)
})

// res => res.data  取出data数据,将来调用接口的时候直接拿到的就是后台的数据
instance.interceptors.response.use(res => res.data, err => {
  // 401 状态码,进入该函数
  if (err.response && err.response.status === 401) {
    // 1. 清空无效用户信息
    // 2. 跳转到登录页
    // 3. 跳转需要传参(当前路由地址)给登录页码
    store.commit('user/setUser', {})
    // 当前路由地址
    // 组件里头:`/user?a=10` $route.path === /user  $route.fullPath === /user?a=10
    // js模块中:router.currentRoute.value.fullPath 就是当前路由地址,router.currentRoute 是ref响应式数据
    const fullPath = encodeURIComponent(router.currentRoute.value.fullPath)
    // encodeURIComponent 转换uri编码,防止解析地址出问题
    router.push('/login?redirectUrl=' + fullPath)
  }
  return Promise.reject(err)
})

// 请求工具函数
export default (url, method, submitData) => {
  // 负责发请求:请求地址,请求方式,提交的数据
  return instance({
    url,
    method,
    // 1. 如果是get请求  需要使用params来传递submitData   ?a=10&c=10
    // 2. 如果不是get请求  需要使用data来传递submitData   请求体传参
    // [] 设置一个动态的key, 写js表达式,js表达式的执行结果当作KEY
    // method参数:get,Get,GET  转换成小写再来判断
    // 在对象,['params']:submitData ===== params:submitData 这样理解
    [method.toLowerCase() === 'get' ? 'params' : 'data']: submitData
  })
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个好好的程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值