轉載自:https://www.cnblogs.com/xiaoliwang/p/10195923.html
開發過程中經常需要用到 nodeJs做轉發層
使用express配合 express-http-proxy 可以輕松的完成轉發
使用過程:
安裝 express-http-proxy
npm install express --save npm install express-http-proxy --save
創建proxy實例
var proxy = require('express-http-proxy');
將客戶端請求轉達到 http://localhost:3001 上:
app.use('/api', proxy('http://localhost:3001', { //過濾器(可選) filter: function(req, res) { return req.method == 'GET'; } //請求路徑解析(可選) proxyReqPathResolver: function(req) { console.log(`請求的路徑:${req.url}`); //請求的路徑:/article/list return `${req.url}?token=123456` //轉發請求路徑: /article/list?token=123456 }, //返回數據處理,如果過程有異步操作應返回Promise(可選) userResDecorator: function(proxyRes, proxyResData, userReq, userRes) { //同步 data = JSON.parse(proxyResData.toString('utf8')); data.newProperty = 'exciting data'; return JSON.stringify(data); //異步 return new Promise(function(resolve) { proxyResData.funkyMessage = 'oi io oo ii'; setTimeout(function() { resolve(proxyResData); }, 200); }); }, }))
如果有多台服務器,可以利用 express-http-proxy 做負載均衡
app.use('/api', proxy(selectProxyHost)) //隨機選擇轉發服務器 function selectProxyHost(){ return (new Date() % 2) ? 'http://google.com' : 'http://altavista.com'; }
例子:
// 訪問 http://localhost:3000/hbapi 會轉為 http://xx.xx.xx.xx:3000 請求
app.use('/ps', proxy('http://'+proxyConfig.URL+':'+proxyConfig1.PORT, {
// forwardPath: function(req, res) {
// debugger
// return require('url').parse(req.url).path;
// }
}))
vue頁面跳轉重定向到express項目下的文件
app.use("/login.html", function (req, res, next) {
res.redirect("/login.html");
next();
});