node跨域转发 express+http-proxy-middleware的使用
程序员文章站
2022-07-04 21:34:45
最近公司在尝试前后端分离的开发模式,现有应用是java语言,要从中间拆除一个小的模块来做前后端分离,工具上还是jquery,只不过是流程和分工上的分离,不想在前端的机器上搭...
最近公司在尝试前后端分离的开发模式,现有应用是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')}`); });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Express之托管静态文件的方法
下一篇: nodejs个人博客开发第七步 后台登陆
推荐阅读
-
使用proxytable 配置解决 vue-cli 的跨域请求问题【推荐】
-
DRF跨域后端解决之django-cors-headers的使用
-
从HTML到node.js以及跨域问题的解决
-
Nginx解决转发地址时跨域的问题
-
使用webpack-dev-server处理跨域请求的方法
-
使用Nginx 反向代理来避免 ajax 跨域请求的方法
-
jQuery使用JSONP实现跨域获取数据的三种方法详解
-
vue使用axios插件请求访问API遇到的跨域问题。
-
新版vue-cli模板下本地开发环境使用node服务器跨域的方法
-
开发中解决Access-Control-Allow-Origin跨域问题的Chrome神器插件,安装及使用