首页 > 编程 > JavaScript > 正文

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

2019-11-19 13:44:44
字体:
来源:转载
供稿:网友

最近公司在尝试前后端分离的开发模式,现有应用是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')}`);});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表