[英]nodejs / restify - Image proxy server
I'm trying to write a simple image proxy server (please feel free to correct me if this isn't the right wording). 我正在尝试编写一个简单的图像代理服务器(如果这不是正确的措辞,请随时纠正我)。
Use case: 使用案例:
This is my current version. 这是我目前的版本。 It appears to serve a broken image file (and open a download prompt when opened via a web browser...).
它似乎提供了一个损坏的图像文件(并通过Web浏览器打开时打开下载提示...)。
UPDATED: Working version below. 更新:下面的工作版本。
var restify = require("restify");
var http = require("http");
var request = require("request");
var server = restify.createServer();
server.listen(1234, function() {
console.log("%s listening at %s", server.name, server.url);
});
server.get("/image", getImage);
function getImage(req, res, next) {
var imageURL = "http://png-5.findicons.com/files/icons/409/witchery/128/cat.png";
http.get(imageURL, function(response) {
var imageSize = parseInt(response.header("Content-Length"));
var imageBuffer = new Buffer(imageSize);
var bytes = 0;
response.setEncoding("binary");
response.on("data", function(chunk) {
imageBuffer.write(chunk, bytes, "binary");
bytes += chunk.length;
});
response.on("end", function() {
console.log("Download complete, sending image.");
res.setHeader("Content-Type", "image/png");
res.send(imageBuffer);
return next();
});
}
Why not simply pipe straight through? 为什么不直接管道?
app.get('/:path', function(req, res) {
request.get('www.imgserver.com/images/' + path).pipe(res);
}
Ok I eventually got it :) 好吧我终于明白了:)
http.get(imageURL, function(response) {
var imageSize = parseInt(response.header("Content-Length"));
var imageBuffer = new Buffer(imageSize);
var bytes = 0;
response.setEncoding("binary");
response.on("data", function(chunk) {
imageBuffer.write(chunk, bytes, "binary");
bytes += chunk.length;
});
response.on("end", function() {
console.log("Download complete, sending image.");
res.setHeader("Content-Type", "image/png");
res.send(imageBuffer);
return next();
});
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.