grayroute.js
2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/**
* 灰度界面代理中间件
* @author h1bomb
*/
var request = require('request');
var config = require('../config/gray');
var _ = require('lodash');
/**
* 灰度界面配置
* @param {Object} proxyRoute
* @return {Function} 返中间件
*/
module.exports = function(proxyRoute) {
return function(req, ress, next) {
//日志记录器
var logger = req.app.logger;
//方法名称
var method = req.method;
//访问路由路径
var path = req.route?req.route.path:'';
//路由的hash key
var key = proxyRoute.genKey(method,path);
//登出,清掉cookie
if(path === '/logout') {
req.session.gray = null;
next();
return;
}
//如果新系统路由没有,代理到老平台
if(!proxyRoute.interfacesConfig[key]) {
//老系统调用地址
var callUrl = config.url + req.originalUrl;
var options = {
method:method,
url:callUrl,
timeout:config.timeout,
headers: req.headers,
useQuerystring:true,
form:req.body
}
//删除提交内容长度,代理会改变长度
delete options.headers['content-length'];
delete options.headers["accept-encoding"];
//设置代理host
options.headers['host'] = config.url.replace('http://','');
if(!req.session.gray) {
logger.log('warn','grayroute: cookie missed',req.session.user);
} else {
options.headers['cookie'] = req.session.gray;
}
logger.log('info','grayroute: request options: %j',options,{});
//发起代理请求
if(req.headers['accept'].indexOf('text/html')>-1||req.xhr) {
request(options,function(err,res,body) {
if(err) {
logger.log('error','grayroute: request error:',err);
ress.status(500).send('');
} else {
var ContentType = res.caseless.get('Content-Type');
ress.append('Content-Type',ContentType);
ress.status(res.statusCode).send(body);
}
});
} else {
request(options).pipe(ress);//如果是静态资源,直接管道传递结果
}
} else {
//当不是老系统的URL,需要访问老系统保持session
request({
method:'GET',
url: config.url + config.sessionKeep,
headers: {
'Cookie':req.session.gray
}
},function(err,res,body){
var code = res?res.statusCode:'no response';
logger.log('info','grayroute: session keep status:'+code);
});
next();
}
}
}