vue.config.js配置前端代理

LinMeng 等级 727 0 0
//官方vue.config.js 参考文档 https://cli.vuejs.org/zh/config/#css-loaderoptions
// 这里只列一部分,具体配置参考文档
module.exports = {
    // 部署生产环境和开发环境下的URL。
    // 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上
    //例如 https://www.my-app.com/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.my-app.com/my-app/,则设置 baseUrl 为 /my-app/。
    //baseUrl 从 Vue CLI 3.3 起已弃用,请使用publicPath
    //baseUrl: process.env.NODE_ENV === "production" ? "./" : "/",
    publicPath: process.env.NODE_ENV === "production" ? "./" : "/",

    // outputDir: 在npm run build 或 yarn build 时 ,生成文件的目录名称(要和baseUrl的生产环境路径一致)
    outputDir: "mycli3",
    //用于放置生成的静态资源 (js、css、img、fonts) 的;(项目打包之后,静态资源会放在这个文件夹下)
    assetsDir: "assets",
    //指定生成的 index.html 的输出路径 (打包之后,改变系统默认的index.html的文件名)
    // indexPath: "myIndex.html",
    //默认情况下,生成的静态资源在它们的文件名中包含了 hash 以便更好的控制缓存。你可以通过将这个选项设为 false 来关闭文件名哈希。(false的时候就是让原来的文件名不改变)
    filenameHashing: false,

    // lintOnSave:{ type:Boolean default:true } 问你是否使用eslint
    lintOnSave: true,
    //如果你想要在生产构建时禁用 eslint-loader,你可以用如下配置
    // lintOnSave: process.env.NODE_ENV !== 'production',

    //是否使用包含运行时编译器的 Vue 构建版本。设置为 true 后你就可以在 Vue 组件中使用 template 选项了,但是这会让你的应用额外增加 10kb 左右。(默认false)
    // runtimeCompiler: false,

    /**
    * 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
    * 打包之后发现map文件过大,项目文件体积很大,设置为false就可以不输出map文件
    * map文件的作用在于:项目打包后,代码都是经过压缩加密的,如果运行时报错,输出的错误信息无法准确得知是哪里的代码报错。
    * 有了map就可以像未加密的代码一样,准确的输出是哪一行哪一列有错。
    * */
    productionSourceMap: false,

    // 它支持webPack-dev-server的所有选项
    devServer: {
    host: "0.0.0.0",
    port: 8080, // 端口号
    https: false, // https:{type:Boolean}
    open: true, //配置自动启动浏览器
    // proxy: 'http://localhost:4000' // 配置跨域处理,只有一个代理

    // 配置多个代理
    proxy: {
    "/api": {
    target: "http://192.168.x.xxx:8090", // 要访问的接口域名
    ws: true, // 是否启用websockets
    changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
    pathRewrite: {
    "^/api": "" //这里理解成用'/api'代替target里面的地址,比如我要调用'http://40.00.100.100:3002/user/add',直接写'/api/user/add'即可
    }
    }
    }
    }
    };

项目中的实战:

    /* 跨域代理 */
    // bmp/bigdipper/view为页面路径,不能做代理,其他非view的都为接口路径,走代理
    open: true, // =>编译完成后会自动打开浏览器
    proxy: {
      '^/api': {
        target: 'http://10.29.32.19:8088/',
        changeOrigin: true,
        ws: true,
        pathRewrite:{
          '^/api':""
        },
        onProxyReq(proxyReq, req, res) {

        },
        onProxyRes(proxyRes, req, res) {
          const cookies = proxyRes.headers['set-cookie'];
          if (cookies) {
            const newCookies = cookies.map((item) => `${item};path=/;Domain=localhost`);
            proxyRes.headers['set-cookie'] = newCookies;
          }
        },
        disableHostCheck: true,
      },

    },
  },

baseURL.js:

个人理解: 代理就是用来解决本地和服务器之间的跨域问题,设置代理后在请求接口的路径中会有/api,,target路径就像是媒介,中转着请求和响应数据

收藏
评论区

相关推荐

vue.config.js配置前端代理
// vue.config.js 配置说明 //官方vue.config.js 参考文档 https://cli.vuejs.org/zh/config/cssloaderoptions // 这里只列一部分,具体配置参考文档 module.exports { // 部署生产环境和开发环境下的URL。 // 默认情况下,Vue CLI
vue cli3打包部署,浏览器缓存问题
问题:每次部署后,页面不更新总是有缓存问题。解决中心思想:在打包文件的文件名中添加一个版本号。方法:在vue.config.js中添加以下代码,vue cli3.x生成的项目默认没有这个文件,需要自己在根目录创建,和package.json同级。 代码块const Timestamp  new Date().getTime();m
「Vue — css」使用sass/scss并定义全局变量
1:安装sassnode languagecnpm install sassnode save dev 2:安装sassloader languagecnpm install sassloader save dev3:在vue.config.js中进行配置 languagemodule.exports css: loaderOptions: s
vue项目无配置文件解决方案
问题在开发vue项目时,需要重新设置项目的启动端口,发现项目目录中并没有相关的配置文件【config目录】vue脚手架版本【通过vue version查询】:@vue/cli 4.5.13解决方案在vue项目根目录下创建vue.config.js配置文件vue.config.jsmodule.exports devServer: d
GIT命令大全
### Git命令大全 ##### Git最小配置 * 某账号下所有的Git仓库都有效 git config --global user.name '您的名称'git config --global user.email '您的Email' * 只对当前Git仓库有效 git conf
GTK+ 程序的编译命令
编译 Hello World 程序的编译命令是: gcc -Wall -g helloworld.c -o helloworld \`pkg-config --cflags gtk+-2.0\` \\ \`pkg-config --libs gtk+-2.0\` 这里使用了程序 pkg-config,可以从 [www.freedesktop.org
MySQL Config
全局参数system\_time\_zone 系统时区,在MySQL启动时会检查当前系统的时区并根据系统时区设置全局参数system\_time\_zone的值。 The system time zone. When the server starts, it attempts to determine the time zone of the hos
Git 手册
`git init                                                  # 初始化本地git仓库(创建新仓库)` `git config --global user.name "xxx"                       # 配置用户名` `git config --global user.emai
Laravel 5.3之 Query Builder 源码解析(中)
$this->tablePrefix = $tablePrefix; $this->config = $config; $this->useDefaultQueryGrammar(); $this->useDefaultPo
Lua增加一个节点到文件中
新建一个文件touch /etc/config/ddns 增加一个节点到文件中 uci set ddns.newadd=config <config>:即配置文件,如ddns,ipv6等 <section-type>: config,global,limit,class,group,system,其它字符 <section>:节点的名字
Qt读写Json格式配置文件
 头文件Config.h #pragma once #include <QVariantMap> class Config { public: Config(const QString &fileName); ~Config(); bool
Spring Cloud Config Client
Spring Cloud Config Client <parent> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-parent</artifactId> <version>Angel.SR4</version> </parent>
Spring Cloud Config Server
Spring Cloud Config Server <parent> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-parent</artifactId> <version>Angel.SR4</version> </parent> <depe
Spring Cloud Config
`nvironmentRepository`的默认实现使用Git后端,这对于管理升级和物理环境以及审核更改非常方便。要更改存储库的位置,可以在Config Server中设置“spring.cloud.config.server.git.uri”配置属性(例如`application.yml`)。如果您使用`file:`前缀进行设置,则应从本地存储库中工作,
vue cli3 打包兼容Android 4.4
原文链接: [vue cli3 打包兼容Android 4.4](https://my.oschina.net/ahaoboy/blog/4716369) 已在Android4.4上跑通 未能兼容ios9, 会报一个type error, 但是又没有其他任何信息, 垃圾ios.... 在vue.config.js中配置相关依赖进行转换 一般把第三方库