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字符串与数组转换汇总
May 26 Javascript
基于jQuery实现点击最后一行实现行自增效果的表格
Jan 12 Javascript
基于Jquery插件实现跨域异步上传文件功能
Apr 26 Javascript
js数组的五种迭代方法及两种归并方法(推荐)
Jun 14 Javascript
JavaScript中误用/g导致的正则test()无法正确重复执行的解决方案
Jul 27 Javascript
利用CSS、JavaScript及Ajax实现图片预加载的方法
Nov 29 Javascript
Vue实现一个返回顶部backToTop组件
Jul 25 Javascript
浅谈React和Redux的连接react-redux
Dec 04 Javascript
react 移动端实现列表左滑删除的示例代码
Jul 04 Javascript
JavaScript函数重载操作实例浅析
May 02 Javascript
react实现复选框全选和反选组件效果
Aug 25 Javascript
Vue ECharts实现机舱座位选择展示功能
May 15 Vue.js
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
德生PL330测评
2021/03/02 无线电
php curl获取网页内容(IPV6下超时)的解决办法
2013/07/16 PHP
PHP获取本周第一天和最后一天示例代码
2014/02/24 PHP
php恢复数组的key为数字序列的方法
2015/04/28 PHP
PHP实现简单爬虫的方法
2015/07/29 PHP
CI框架表单验证实例详解
2016/11/21 PHP
php使用PDO执行SQL语句的方法分析
2017/02/16 PHP
PHP实现的62进制转10进制,10进制转62进制函数示例
2019/06/06 PHP
网页的标准,IMG不支持onload标签怎么办
2006/06/29 Javascript
8个超棒的学习 jQuery 的网站 推荐收藏
2011/04/02 Javascript
深入理解JavaScript系列(1) 编写高质量JavaScript代码的基本要点
2012/01/15 Javascript
JavaScript 中的日期和时间及表示标准介绍
2013/08/21 Javascript
jquery delay()介绍及使用指南
2014/09/02 Javascript
javascript基本语法
2016/05/31 Javascript
浅谈js的html元素的父节点,子节点
2016/08/06 Javascript
vue调用高德地图实例代码
2017/04/28 Javascript
基于JS递归函数细化认识及实用实例(推荐)
2017/08/07 Javascript
使用JS组件实现带ToolTip验证框的实例代码
2017/08/23 Javascript
实时监控input框,实现输入框与下拉框联动的实例
2018/01/23 Javascript
[48:41]VP vs VG Supermajor小组赛 B组胜者组决赛 BO3 第二场 6.2
2018/06/03 DOTA
Python 时间处理datetime实例
2008/09/06 Python
python二维列表一维列表的互相转换实例
2018/07/02 Python
Pandas之read_csv()读取文件跳过报错行的解决
2020/04/21 Python
tensorflow下的图片标准化函数per_image_standardization用法
2020/06/30 Python
python 两种方法删除空文件夹
2020/09/29 Python
瑞士香水购物网站:Parfumcity.ch
2017/01/14 全球购物
澳洲女装时尚在线:Blue Bungalow
2018/05/05 全球购物
荷兰在线钓鱼商店:Raven
2019/06/26 全球购物
锐步香港官方网上商店:Reebok香港
2020/11/05 全球购物
控制工程专业个人求职信
2013/09/25 职场文书
20岁生日感言
2014/01/13 职场文书
司仪主持词两篇
2014/03/22 职场文书
高三学生评语大全
2014/04/25 职场文书
胡桃夹子观后感
2015/06/11 职场文书
python疲劳驾驶困倦低头检测功能的实现
2022/04/04 Python
Python matplotlib 利用随机函数生成变化图形
2022/04/26 Python