node跨域转发 express+http-proxy-middleware的使用


Posted in Javascript onMay 31, 2018

最近公司在尝试前后端分离的开发模式,现有应用是java语言,要从中间拆除一个小的模块来做前后端分离,工具上还是jquery,只不过是流程和分工上的分离,不想在前端的机器上搭建一套java环境,就根据教程搭了一下转发,让本地可以接上开发服务器联调。

为什么要使用node代理转发?

我们要实现前后端分离,然后前端不在自己的电脑上安装tomcat,这时候,我们通过用node搭建服务器,然后转发我们的请求。例如:自己本地是localhost:3000,我们需要访问http://www.example.com(当然,开发过程中,这个应该是你们后台的tomcat的地址), 来做ajax的数据交互。

创建项目

npm init

安装模块

npm install express connect-timeout http-proxy-middleware --save-dev

创建js文件

<!--proxy-server.js-->
const express = require('express');
const timeout = require('connect-timeout');
const proxy = require('http-proxy-middleware');
const app = express();

// 超时时间
const TIME_OUT = 30 * 1e3;

// 设置端口
app.set('port', '80');

// 设置超时 返回超时响应
app.use(timeout(TIME_OUT));
app.use((req, res, next) => {
 if (!req.timedout) next();
});


proxyOption = {
 target: 'http://localhost:8080',
 pathRewrite: {
    '^/api/' : '/' // 重写请求,api/解析为/
  },
  changeOrigoin:true
};

// 静态资源路径
app.use('/', express.static('src/page'));

// 反向代理
app.use('/api/*', proxy(proxyOption));

// 监听端口
app.listen(app.get('port'), () => {
 console.log(`server running @${app.get('port')}`);
});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
纯CSS打造的导航菜单(附jquery版)
Aug 07 Javascript
Jquery插件之打造自定义的select标签
Nov 30 Javascript
JavaScript栏目列表隐藏/显示简单实现
Apr 03 Javascript
JS判定是否原生方法
Jul 22 Javascript
javascript实现3D变换的立体圆圈实例
Aug 06 Javascript
JavaScript深度复制(deep clone)的实现方法
Feb 19 Javascript
JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
May 31 Javascript
js原生实现FastClick事件的实例
Nov 20 Javascript
深入理解vue $refs的基本用法
Jul 13 Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 Javascript
微信小程序canvas实现刮刮乐效果
Jul 09 Javascript
electron踩坑之dialog中的callback解决
Oct 06 Javascript
Vue实现侧边菜单栏手风琴效果实例代码
May 31 #Javascript
Node.js笔记之process模块解读
May 31 #Javascript
Vue组件中prop属性使用说明实例代码详解
May 31 #Javascript
用JS实现根据当前时间随机生成流水号或者订单号
May 31 #Javascript
Vue2 轮播图slide组件实例代码
May 31 #Javascript
vue2.0+vuex+localStorage代办事项应用实现详解
May 31 #Javascript
JavaScript 中的12种循环遍历方法【总结】
May 31 #Javascript
You might like
探讨PHP删除文件夹的三种方法
2013/06/09 PHP
一个简单至极的PHP缓存类代码
2015/10/23 PHP
php 开发中加密的几种方法总结
2017/03/22 PHP
PHP针对redis常用操作实例详解
2019/08/17 PHP
Yii框架常见缓存应用实例小结
2019/09/09 PHP
用js实现的抽象CSS圆角效果!!
2007/05/03 Javascript
JavaScript几种形式的树结构菜单
2010/05/10 Javascript
js如何获取file控件的完整路径具体实现代码
2013/05/15 Javascript
node.js中的fs.chmod方法使用说明
2014/12/18 Javascript
基于jQuery实现在线选座之高铁版
2015/08/24 Javascript
15个常用的jquery代码片段
2015/12/19 Javascript
JavaScript中子对象访问父对象的方式详解
2016/09/01 Javascript
过期软件破解办法实例详解
2017/01/04 Javascript
9种使用Chrome Firefox 自带调试工具调试javascript技巧
2017/12/22 Javascript
vue组件间通信六种方式(总结篇)
2019/05/15 Javascript
JS关闭子窗口并且刷新上一个窗口的实现示例
2020/03/10 Javascript
Vue+Spring Boot简单用户登录(附Demo)
2020/11/12 Javascript
[01:50]《我与DAC》之玩家:iG夺冠时的那面红旗
2018/03/29 DOTA
介绍Python中的__future__模块
2015/04/27 Python
Python 实现一个颜色色值转换的小工具
2016/12/06 Python
Django项目中包含多个应用时对url的配置方法
2018/05/30 Python
Python sorted函数详解(高级篇)
2018/09/18 Python
使用CodeMirror实现Python3在线编辑器的示例代码
2019/01/14 Python
python re.sub()替换正则的匹配内容方法
2019/07/22 Python
基于Tensorflow:CPU性能分析
2020/02/10 Python
Python 实现打印单词的菱形字符图案
2020/04/12 Python
一个非常简单好用的Python图形界面库(PysimpleGUI)
2020/12/28 Python
CSS3制作酷炫的三维相册效果
2016/07/01 HTML / CSS
Too Faced官网:美国知名彩妆品牌
2017/03/07 全球购物
印度尼西亚最大的电商平台:Tokopedia(印尼版淘宝)
2017/12/02 全球购物
微观物理专业自荐信
2014/01/26 职场文书
2014年五一活动策划方案
2014/03/15 职场文书
公司采购主管岗位职责
2014/06/17 职场文书
店铺转让协议书
2015/01/29 职场文书
好人好事新闻稿
2015/07/17 职场文书
详解OpenCV曝光融合
2022/04/29 Python