[英]How to modify response headers with express-http-proxy
我正在使用express-http-proxy代理我的SPA(单页应用程序)和CouchDB实例之间的一些请求。 我是在每个呼叫的基础上执行此代理,而不是创建代理服务器(此刻将很重要)。
当前使用示例
app.use(`some/url`, proxy(dburl, {
forwardPath: req => {return 'some/url'+require('url').parse(req.url).path;}
}) );
这意味着我没有使用httpProxy.createServer
。 我想发送一些文本数据片段以及我的回复作为标题。 浏览完文档后,我得出的结论是,我要使用的是intercept
。 不幸的是,我还没有完全掌握如何使用它,到目前为止,我发现的唯一 相关 问题似乎是基于httpProxy.createServer
(根据我的有限理解)工作方式有所不同。
我们之所以使用单个请求代理,是因为我们希望将不同的请求代理到不同的微服务,并且发现这是做到这一点的最简洁的方式(我们知道并当时)。
给定代码
const text = 'asdf';
app.use(`some/url`, proxy(dburl, {
forwardPath: req => {return 'some/url'+require('url').parse(req.url).path;},
intercept: function(rsp, data, req, res, callback) {
//SUSPECT LOCATION
}
}) );
在SUSPECT LOCATION
是否有一些代码可以使我在标题上放置text
以进行最终响应,而又不影响(当前以其他方式工作的)代理?
总的来说,标题和网络请求对我不是很熟悉,如果答案似乎不言而喻,我深表歉意。
指向资源的链接的加分点可以帮助您解释使用此库进行代理的更好之处,用于代理的类似库或可以清楚地说明如何使用该库进行代理的基础技术。 再次,我宁愿花一些自己的时间进一步研究这个问题,而不会再提出其他问题。
我并不完全相信我的代码所在的SUSPECT LOCATION
是“ SUSPECT LOCATION
,如果它需要移到其他地方,或者是否需要以其他方式解决这个问题,我会很乐意听。
它遵循req,res对象上的express.js方法。
在拦截函数主体中,使用以下快速格式设置响应头。
res.set('hola', 'amigos!!!');
请参考以下链接:
http://expressjs.com/en/4x/api.html#res.set
没有文档时理解库的最好方法是遵循其测试套件。 如果没有测试套件,请不要使用该库。
这是express-http-proxy拦截功能的测试套件
https://github.com/villadora/express-http-proxy/blob/master/test/intercept.js
这是测试用例
it('can modify the response headers', function(done) {
var app = express();
app.use(proxy('httpbin.org', {
intercept: function(rsp, data, req, res, cb) {
res.set('x-wombat-alliance', 'mammels');
res.set('content-type', 'wiki/wiki');
cb(null, data);
}
}));
request(app)
.get('/ip')
.end(function(err, res) {
if (err) { return done(err); }
assert(res.headers['content-type'] === 'wiki/wiki');
assert(res.headers['x-wombat-alliance'] === 'mammels');
done();
});
});
如果您想不了解代理的内容,最好的资源是haproxy
http://cbonte.github.io/haproxy-dconv/1.7/intro.html
但在此之前,您需要进一步了解http(建设性评论)
接受的答案现在已过时。 拦截不再存在。
而是在代理功能之前使用自己的中间件
router.route('/my-route').get((req, res, next) => {
res.set('My-Header', 'my-header-value');
next();
}, proxyFunction);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.