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 相关文章推荐
深入理解JavaScript系列(49):Function模式(上篇)
Mar 04 Javascript
javascript笛卡尔积算法实现方法
Apr 08 Javascript
详解javascript遍历方式
Nov 11 Javascript
javascript每日必学之多态
Feb 23 Javascript
JS中JSON对象和String之间的互转及处理技巧
Apr 06 Javascript
JavaScript函数中关于valueOf和toString的理解
Jun 14 Javascript
JS获取年月日时分秒的方法分析
Nov 28 Javascript
深入理解requireJS-实现一个简单的模块加载器
Jan 15 Javascript
JavaScript分步实现一个出生日期的正则表达式
Mar 22 Javascript
vue项目接口管理,所有接口都在apis文件夹中统一管理操作
Aug 13 Javascript
vue 如何从单页应用改造成多页应用
Oct 23 Javascript
微信小程序实现滚动Tab选项卡
Nov 16 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利用COM对象访问SQLServer、Access
2006/10/09 PHP
php中数组首字符过滤功能代码
2012/07/31 PHP
zend framework中使用memcache的方法
2016/03/04 PHP
jQuery版仿Path菜单效果
2011/12/15 Javascript
jQuery获取浏览器中的分辨率实现代码
2013/04/23 Javascript
js动态创建表格,删除行列的小例子
2013/07/20 Javascript
浅析JavaScript中的CSS属性及命名规范
2013/11/28 Javascript
AngularJS模块学习之Anchor Scroll
2016/01/19 Javascript
jQuery解决$符号命名冲突
2016/06/18 Javascript
Bootstrap树形菜单插件TreeView.js使用方法详解
2016/11/01 Javascript
使用vue.js写一个tab选项卡效果
2017/03/25 Javascript
详解前端路由实现与react-router使用姿势
2017/08/07 Javascript
vue实现页面加载动画效果
2017/09/19 Javascript
Node.js搭建小程序后台服务
2018/01/03 Javascript
QRCode.js二维码生成并能长按识别
2018/10/16 Javascript
jQuery 动态粒子效果示例代码
2020/07/07 jQuery
VsCode里的Vue模板的实现
2020/08/12 Javascript
wxPython窗口的继承机制实例分析
2014/09/28 Python
Python实现将绝对URL替换成相对URL的方法
2015/06/28 Python
python僵尸进程产生的原因
2017/07/21 Python
Python编程实现正则删除命令功能
2017/08/30 Python
python机器学习之神经网络(一)
2017/12/20 Python
python得到单词模式的示例
2018/10/15 Python
python basemap 画出经纬度并标定的实例
2019/07/09 Python
在Python中os.fork()产生子进程的例子
2019/08/08 Python
Python基础之字典常见操作经典实例详解
2020/02/26 Python
用python对oracle进行简单性能测试
2020/12/05 Python
英国领先的汽车轮胎和快速健康中心:Kwik Fit
2017/10/29 全球购物
印度尼西亚最好的小工具在线商店:Erafone.com
2019/03/26 全球购物
罗技美国官网:Logitech美国
2020/01/22 全球购物
法国亚马逊官方网站:Amazon.fr
2020/12/19 全球购物
法制宣传教育方案
2014/05/09 职场文书
大学生个人求职信例文
2014/07/07 职场文书
邀请函样本
2015/02/02 职场文书
2016年基层党组织创先争优承诺书
2016/03/25 职场文书
最新最全的手机号验证正则表达式
2022/02/24 Javascript