加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 08:18:52 所属栏目:百科 来源:网络整理
导读:最近公司在尝试前后端分离的开发模式,现有应用是java语言,要从中间拆除一个小的模块来做前后端分离,工具上还是jquery,只不过是流程和分工上的分离,不想在前端的机器上搭建一套java环境,就根据教程搭了一下转发,让本地可以接上开发服务器联调。 为什么

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

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

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

创建项目

安装模块

创建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')});
});

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读