轉載自: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();
});

