node跨域转发 express+http

网友投稿 361 2023-01-30


node跨域转发 express+http

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

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

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

创建项目

npm init

安装模块

npm install express connect-timeout http-proxy-middleware --save-dev

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

});


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序登录换取token的教程
下一篇:Vue2 轮播图slide组件实例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~