如何配置 vue.config.js 解决跨域?(解决生产环境中的跨域问题,举例:vue-admin-template)以及axios的配置
vue-admin-template
PanJiaChen/vue-admin-template: 基于 Vue.js 和 Element UI 的后台管理系统模板,支持多语言、主题和布局切换。该项目提供了一个完整的后台管理系统模板,可以方便地实现后台管理系统的快速搭建和定制,同时支持多种数据源和插件扩展。
项目地址:https://gitcode.com/gh_mirrors/vu/vue-admin-template
免费下载资源
·
原理:
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
})
}
GitHub 加速计划 / vu / vue-admin-template
16
5
下载
PanJiaChen/vue-admin-template: 基于 Vue.js 和 Element UI 的后台管理系统模板,支持多语言、主题和布局切换。该项目提供了一个完整的后台管理系统模板,可以方便地实现后台管理系统的快速搭建和定制,同时支持多种数据源和插件扩展。
最近提交(Master分支:4 个月前 )
4c18a3f4 - 3 年前
714ded11 - 4 年前
更多推荐
已为社区贡献3条内容
所有评论(0)