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 相关文章推荐
jquery 模拟类搜索框自动完成搜索提示功能(改进)
May 24 Javascript
JS原型对象通俗&quot;唱法&quot;
Dec 27 Javascript
jQuery获得内容和属性示例代码
Jan 16 Javascript
php常见的页面跳转方法汇总
Apr 15 Javascript
AngularJS ng-bind-html 指令详解及实例代码
Jul 30 Javascript
jQuery EasyUI的TreeGrid查询功能实现方法
Aug 08 jQuery
Vue filter介绍及详细使用
Apr 04 Javascript
详解基于Node.js的HTTP/2 Server实践
May 31 Javascript
JS实现监控微信小程序的原理
Jun 15 Javascript
详解js获取video任意时间的画面截图
Apr 17 Javascript
js单线程的本质 Event Loop解析
Oct 29 Javascript
vue 授权获取微信openId操作
Nov 13 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(1)
2006/10/09 PHP
默认让页面的第一个控件选中的javascript代码
2009/12/26 Javascript
浅谈javascript的原型继承
2012/07/25 Javascript
jquery $.each()使用探讨
2013/09/23 Javascript
NodeJS学习笔记之MongoDB模块
2015/01/13 NodeJs
js实现缓冲运动效果的方法
2015/04/10 Javascript
JavaScript基础篇(6)之函数表达式闭包
2015/12/11 Javascript
学习jQuey中的return false
2015/12/18 Javascript
第一篇初识bootstrap
2016/06/21 Javascript
Vue表单验证插件Vue Validator使用方法详解
2017/04/07 Javascript
Vue异步组件使用详解
2017/04/08 Javascript
解决Jstree 选中父节点时被禁用的子节点也会选中的问题
2017/12/27 Javascript
vue2.0 + ele的循环表单及验证字段方法
2018/09/18 Javascript
Javascript实现秒表倒计时功能
2018/11/17 Javascript
通过js给网页加上水印背景实例
2019/06/17 Javascript
详解Python的迭代器、生成器以及相关的itertools包
2015/04/02 Python
python中循环语句while用法实例
2015/05/16 Python
Django入门使用示例
2017/12/12 Python
Python多重继承的方法解析执行顺序实例分析
2018/05/26 Python
解决PyCharm控制台输出乱码的问题
2019/01/16 Python
Jupyter notebook 启动闪退问题的解决
2020/04/13 Python
Python使用Paramiko控制liunx第三方库
2020/05/20 Python
什么是python的自省
2020/06/21 Python
利用Python批量识别电子账单数据的方法
2021/02/08 Python
详解CSS透明opacity和IE各版本透明度滤镜filter的最准确用法
2016/12/20 HTML / CSS
HTML5: Web 标准最巨大的飞跃
2008/10/17 HTML / CSS
bareMinerals官网:矿物质化妆品和护肤品
2018/02/04 全球购物
Java语言程序设计测试题判断题部分
2013/01/06 面试题
应用电子技术专业个人求职信
2013/09/21 职场文书
简单的大学生自我鉴定
2014/02/18 职场文书
《小松树和大松树》教学反思
2014/02/20 职场文书
晨会主持词
2014/03/17 职场文书
学校法制宣传日活动总结
2014/11/01 职场文书
2019年大学推荐信
2019/06/24 职场文书
MySQL中IO问题的深入分析与优化
2022/04/02 MySQL
动作冒险《Hell Is Us》将采用虚幻5 消灭怪物探索王国
2022/04/13 其他游戏