vue中使用proxy配置不同端口和ip接口

时间: 2019-07-13阅读: 284标签: 接口

问题描述:

使用vue-cli创建的项目,开发地址是localhost:8080,由于后台开发不同的模块,导致每个模块请求的ip和端口号不一致

例如:http://192.168.10.22:8081  或者 http://192.168.10.30:9999等


解决问题:

在vue.config.js中配置不同的端口号

module.exports = {
publicPath: process.env.NODE_ENV === 'production' ? './' : '/',
    devServer: {
        open: true,
        proxy: {
            '/monitor': {                          // 配置的变量
                target: 'http://192.168.10.30:9999',          // 需要请求的第三方接口
                changeOrigin: true,                    // 开启代理:在本地会创建一个虚拟服务器,然后发送请求,并同时接收请求,这样服务端和服务端进行交互就不会有跨域问题
                pathRewrite: {                       // 这里重写路径,如果monitor本身不存在接口路径中,一定要写成空!!!
                    '^/monitor': ''
                },
                ws: false
            }
        }
    }
}

在调用该接口的时候,需要写上'/monitor/'

export const getDictionary = ((params) => {
    return _axios({
        url:  '/monitor/keypersonnel/getDictionaryForType',
        method: 'post',
        data: params
    })
})

备注:proxy代理只在本地测试的开发环境有效,在部署到线上的时候应该怎么区分呢


问题:

若项目中不同模块请求不同ip和端口的接口,应该怎么设为可配置的呢,后端可以修改的,避免由于接口问题导致的不断的打包上线


思路一:在public目录下放置json文件,配置的时候,去读取json文件

<template>
  <div>
    <el-scrollbar>
      <div>
        <img
          class="sdde"
          :src='`${publicPath}imges/but_play.png`'
        >
      </div>
    </el-scrollbar>
  </div>
</template>

<script>
export default {
  data() {
    return {
      publicPath: process.env.BASE_URL
    }
  },
  components: {
  }

}
</script

结果: 失败!给图片的src赋值成功,但是在create中按照同样的方法去require这个json文件,还是报路径错误


思路二: 在public中新建js文件,在js文件中,将地址挂载到window上,并在index的html文件中引入

// 配置线上的请求地址
window.serverUrl = {
    publicSentiment: 'http://192.168.10.22:8081',                       // 舆情分析
    monitor: 'http://192.168.70.6:9999'                                 // 重点人员监控
}

结果:成功!


吐血推荐

1.站长广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入...

2.休闲娱乐: 网页游戏  直播/交友   H5游戏

链接: http://www.fly63.com/article/detial/4668

JSON API免费接口

各种提供JSON格式数据返回服务网站的API接口,为大家搜集了一些能够返回JSON格式的服务接口。部分需要用JSONP调用。

Mock.js模拟接口数据

现在开发已经是前后端分离了,前端和后端可以同时进行开发,互不影响,但是有些时候后端开发的接口慢于前端,导致前端需要等待后端的接口完成才能完成前后端对接,为了解决这个痛点,出现了模拟接口数据的方案

接口

接口的作用:在面向对象的编程中,接口是一种规范的定义,它定义了行为和动作的规范,在程序设计里面,接口起到一种限制和规范的作用。接口定义了某一批类所需要遵守的规范,接口不关心这些类的内部状态数据

vue项目用到的mock数据接口的两种方式

使用devServer.before进行数据mock,通过配置devServer.before选项,设置url访问路径及response响应数据,进行mock数据。使用Mock.js进行数据mock根据数据模板生成模拟数据。

如何使用 React hooks 获取 api 接口数据

在本教程中,我想向你展示如何使用 state 和 effect 钩子在React中获取数据。 你还将实现自定义的 hooks 来获取数据,可以在应用程序的任何位置重用,也可以作为独立节点包在npm上发布。

前后端分离,接口对接问题

关于前后端对接问题下面好程序员web前端学习路线为大家解答。对于前后端分离开发,必须要写接口文档。否则,第一:前后端开发没有标准,没有依据。第二:容易扯皮,没法追踪,职责不清

vue项目接入mock&& axios 通用配置

兵马未动,粮草先行; 同理,项目开发过程中经常会出现接口未出, 前端页面已搭建完毕的情况;此时为了提高前端的开发效率,解放生产力,我们 FE 可以按照预定的接口文档做一些接口模拟的工作

从TypeScript中的类中派生接口

大多数面向对象编程语言都鼓励编程到接口的模式。 TypeScript 当然支持这一点,你可以创建一个或多个接口,然后再定义生成这个接口实例的类(或工厂)。但是当程序员预期将来可能会存在多个具体实现时,有时会过度使用对接口的编程

TypeScript接口

接口的作用是声明变量的结构和方法,但不做具体的实现。通常,接口会强制对所有成员进行类型检查,包括数量和类型:带有可选属性的接口与普通的接口定义差不多

你不得不了解的前后端分离原理!

前后端分离已成为互联网项目开发的业界标准使用方式,通过nginx+tomcat的方式(也可以中间加一个nodejs)有效的进行解耦,并且前后端分离会为以后的大型分布式架构、弹性计算架构

fly63.com版权所有,内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权,请与小编联系!情况属实本人将予以删除!

广告赞助文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯幽默笑话段子句子语录成语大全