首页 > 其他分享 >【Vue】代理服务配置

【Vue】代理服务配置

时间:2022-12-08 23:13:20浏览次数:47  
标签:API VUE 代理服务 APP 配置 路径 Vue BASE axios

 

Springboot 后台接口地址

基础路径配置:

server:
  port: 8080
  servlet:
    context-path: /demo

  

完整路径:

localhost:8080/demo

  

 

Vue无代理服务配置

.env.development文件配置后台接口和对应path

# just a flag
ENV = 'development'

# base api
VUE_APP_BASE_DOMAIN = 'http://localhost:8080'
VUE_APP_BASE_API = '/demo'

 

在utils/request.js文件中,更改基础地址:

import axios from 'axios'
import { MessageBox, Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'

/**
 * create an axios instance
 * 创建 axios实例
 * @type {AxiosInstance} axios实例
 */
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_DOMAIN + process.env.VUE_APP_BASE_API, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // 请求超时时间 request timeout
})

 

npm run dev 重启后 接口就是请求后台的了

但是没有配置代理服务,请求会出现一个问题:每个请求都会附带一个[OPTION]预检请求

开发的时候混在一起调试很麻烦

 

Vue 代理服务配置

定义目标接口,目标API的路径,和代理路径

# just a flag
ENV = 'development'

# base api
VUE_APP_BASE_DOMAIN = 'http://localhost:8080'
VUE_APP_BASE_API = '/demo'
VUE_APP_PROXY_API = '/proxy-api'

  

Request.js只需要填写代理路径,默认拼接web地址为前缀

import axios from 'axios'
import { MessageBox, Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'

/**
 * create an axios instance
 * 创建 axios实例
 * @type {AxiosInstance} axios实例
 */
const service = axios.create({
  baseURL: process.env.VUE_APP_PROXY_API, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // 请求超时时间 request timeout
})

 

Vue.config.js配置devServer时,追加代理配置:

  devServer: {
    port: port,
    open: true,
    overlay: {
      warnings: false,
      errors: true
    },
    /* 配置代理服务,解决接口跨域访问问题 */
    proxy: {
      /* 匹配所有以[代理路径]开头的路径 */
      [process.env.VUE_APP_PROXY_API]: {
        /* 代理目标的基础路径 就是实际后台接口 */
        target: process.env.VUE_APP_BASE_DOMAIN,
        /* 路径重写,匹配[代理路径]开头的字符串,并把[代理路径]替换为空字符串 路径重写时把[代理路径]替换回[实际Api路径] */
        pathRewrite: { [`^${process.env.VUE_APP_PROXY_API}`]: process.env.VUE_APP_BASE_API },
        /* 支持websocket */
        ws: true,
        /* 请求来自于。即控制请求头中host数据。默认为true说谎:来自8080; false如实回答来自代理服务器8081 */
        changeOrigin: true
      }
    }
    /* 不使用mockJS的接口数据 */
    /* before: require('./mock/mock-server.js') */
  },

  

 

标签:API,VUE,代理服务,APP,配置,路径,Vue,BASE,axios
From: https://www.cnblogs.com/mindzone/p/16967682.html

相关文章

  • #yyds干货盘点#vue框架computed的原理
    computed原理,首先得讲vue响应式原理,因为computed的实现是基于​​Watcher​​​对象的。那么vue的响应式原理是什么呢?众所周知,vue是基于​​Object.definePrope......
  • Django简介及安装、配置
    Django简介及安装、配置python主流web框架Django:特点是大而全这个特点意味着它功能的强大,也意味着它资源的臃肿,但是总体上还是瑕不掩瑜的一个框架。flask:特点是小而精......
  • Vue滑块验证
    登陆时加入滑块验证1、在src\components新建SilderVerify\index.vue文件<template><divclass="silder-range":class="rangeStatus?'success':''"><i@mousedo......
  • vue实现自定义字体库
      先看效果是不是你所需要的,再看具体如何实现。   效果如下图所示:         有些字体需要下载,用图片就会变得很不清楚,这样我们就需要去下载字......
  • Vue2.0 中使用Less
    第一步  npm安装lessnpminstalllessless-loader--save 第二步 修改webpack.base.conf.js文件,配置loader加载依赖,让其支持外部的less,在原来的代码上添加如下......
  • Kylin-配置ISCSI服务-网络存储
    Kylin-ISCSI服务配置部署ISCSI服务端和客户端实现网络存储复查完成部署ISCSI服务端-server.kylin.com部署共享硬盘,部署共享资源验证:安装targetcli......
  • 0006. Web32环境配置
    mkvirtualenv-p/usr/bin/python3web32创建虚拟环境workon查看虚拟环境workon虚拟环境名切换虚拟环境#!!!下载模块需要切换到对应的虚拟环境中下载pycharm中......
  • wince界面优化配置
    wince下隐藏任务栏大概有以下几种方法:(1)通过修改注册表;(2)在应用程序初始化的时候中加入一段代码,将任务栏窗口隐藏。(3)直接修改explorer的代码,重新编译连接。三种方法我都尝试了......
  • Nginx_高可用配置(keepalived+nginx主从热备双机架构)!
    系统版本Centos7IP:192.168.8.145MasterIP:192.168.8.150Slave一.Linux安装nginx(主从都安装NGINX)1.安装依赖[root@Master~]#yum-yinstallgcczlibzlib-devel......
  • Vue刷新后页面数据丢失问题的解决过程
    OverridetheentrypointofanimageIntroducedinGitLabandGitLabRunner9.4.Readmoreaboutthe extendedconfigurationoptions.Beforeexplainingtheav......